1、若有宏定义:#define MOD(x,y)x%y,则执行以下语句后的输出结果是(B)
int a=13,b=94;
printf("%d\n",MOD(b,a+4));
A.5 B.7 C.9 D.11
解析:因为#define MOD(x,y) x%y是在运行时直接代入计算。
所以实际上计算的结果是MOD(b,a+4),即printf(″%d\n″,b%a+4);
b%a=3,所结果是3+4=7
2、表达式strcmp("2.56","4.728")的值是一个(A);
A.非零整数 B.浮点数 C.0 D.字符
3、设struct{short a;char b;float c;}str;则sizeof(str)的值是(E)
A.4B.5C.6D.7 E.8
4、设#define N 3
#define Y(n) (N+1)*n
则表达式2*(N+Y(5+1))的值是(B);
A.42B.48C.54D.出错
解析:2*(3+(3+1)*5+1) = 48
5、下述程序执行后的输出结果是(A)
#define
main(){
int x='f';
printf("%c\n",'a'+(x-'a'+1));
}
A.gB.hC.iD.j
解析:a的ASCII值是97 A的ASCII值是65.
6、下列程序段运行后,x的值是(A)
a=1;b=2;x=0;
if(!(--a))x--;
if(!b)x=7;
else ++x;
A.0B.3C.6D.7
解析:--a的结果是0;!0的结果是1,,所以第一个if满足条件,x--; 此时x为-1;!b的结果是0,所以第二个if不满足条件,执行else ++x所以x为0
7、void foo(int [][3]);
main(){
int a[3][3]={ {1,2,3},{4,5,6},{7,8,9}};
foo(a);
printf("%d",a[2][1]);
}
void foo(int b[][3])
{
++b;
b[1][1] = 9;
}
这段程序的输出是(B)
A.8B.9C.7D.都不是
解析:foo(a);是用a调用函数foo,在foo中b就指向了a[0](就是a数组中的1的位置),++b使b指向了a[1](就是a数组中的4的位置),即现在的b[0]指向4、b[1]指向7;那么,b[1][1]显然就是元素8,b[1][1]=9;的语句把8改成了9。函数返回后,输出的是a[2][1],就是定义中的8的位置,可是刚才在foo中不是把8已改成9了吗?所以输出是9。