1.以下程序的输出结果是()
#include
int main()
{
int x=3,y=3;
switch(x%2)
{
case 1:
switch (y)
{
case 0:
cout<<"first";
case 1:
cout<<"second";
break;
default:
cout<<"hello";
}
case 2:
cout<<"third";
}
return 0;
}
A second third
B hello
C first second
D hellothird
看到case我们就需要注意break是否存在了,x%2 = 1,进入case1;y=3,进入default语句;把hello打印出来default后没有break语句跳出循环,所以还是要执行case2,再打印出third,最后打印出来的是hellothird
2.以下能对二维数组a进行正确初始化的语句是()
A int ta[2][]={{0,1,2},{3,4,5}};
B int ta[][3]={{0,1,2},{3,4,5}};
C int ta[2][4]={{0,1,2},{3,4},{5}};
D int ta[][3]={{0,2},{},{3,4,5}};
解析:
二维数组的初始化
行可以省略,列不可省略;
最外面的“{}”代表行,内部的“{}”代表列。例如,对于“{{0,1,2},{3,4,5}}”,{0,1,2}和{3,4,5}代表了两行元素,其中0,1,2和3,4,5代表了三列元素;
初始化每一行的时候,必须连续初始化。D不对
本题选B。
3.设变量已正确定义,以下不能统计出一行中输入字符个数(不包含回车符)的程序段是
A. n=0;while(ch=getchar()!='\n')n++;
B. n=0;while(getchar()!='\n')n++;
C. for(n=0;getchar()!='\n';n++);
D. n=0;for(ch=getchar();ch!='\n';n++);
getchar()
从键盘的输入中获取单个字符
• for( 初始化部分;条件判断;调整部分 )
for循环的初始化部分(D项为ch=getchar())只执行一次,getchar()无法再获取后续的字符,故无法统计输入字符的个数。
本题选D。
4.能把函数处理结果的二个数据返回给主调函数,在下面的方法中不正确的是()
A return这二个数
B 形参用数组
C 形参用二个指针
D 用二个全局变量
return只能返回一个值,不能返回两个,选A
5.32位系统中,定义**a[3][4],则变量占用内存空间为()
A. 4 B. 48 C. 192 D. 12
• 任何类型的指针在32位系统下占4字节,在64位系统下占8字节
[]的优先级比*高,a先与[]结合为一个三行四列的数组。数组中存放的是一个“**”类型,即一个没有明确所指变量类型的二级指针类型,故a是一个指针数组。数组中一共有3x4=12个指针,在32位系统下,每个指针占4字节,故数组a总共占48个字节。
本题选B。
6.假设在一个 32 位 little endian(小端)的机器上运行下面的程序,结果是多少?
#include
int main(){
long long a = 1, b = 2, c = 3;
printf("%d %d %d\n", a, b, c);
return 0;
}
A. 1,2,3 B. 1,0,2 C. 1,3,2 D. 3,2,1
大端字节序的概念是,把一个数据低位字节处的数据放在高地址处,高位字节处的数据放在低地址处
小端字节序的概念是,把一个数据低位字节处的数据放在低地址处,高位字节处的数据放在高地址处栈从高地址向低地址增长
7.以下程序的输出结果是()
#include
int main() {
char a[10] = {'1', '2', '3', '4', '5', '6', '7', '8', '9', 0}, *p;
int i;
i = 8;
p = a + i;
printf("%s\n", p - 3);
}
A 6
B 6789
C ‘6’
D 789
a是数组名,所以指向数组首元素;p=a+8:a向右偏移8个字节,指向‘9’。p - 3也就是向左偏移3个字节,对于%s打印:遇到\0停止打印,打印出6789
8.下面3段程序代码的效果一样吗()
int b;
(1)const int *a = &b;
(2)int const *a = &b;
(3)int *const a = &b;
A (2)=(3)
B (1)=(3)
C (1)=(2)
D 都不一样
看const在*的左右即可,1和2是常量指针,3是指针常量