1.打印一个整型数据,要求这个数为负数前面输出负号,这个数为正数前面输出正号。
printf("%+d", n);
注:在printf输出控制中+表示输出符号(正号或负号)。-表示结果左对齐,右边填空格,如果不加则表示右对齐。
例如:printf("%-8+d", n); //宽度为8左对齐带符号输出
2.下面代码的输出结果为?
#include
#include
int main(void)
{
int x = 3, y = 4, z = 5;
printf("%d", ~((x ^ y) && !z));
return EXIT_SUCCESS;
}
输出:-1
分析:x^y的结果为真,!z的结果为假,所以整个&&的判断结果为假,所以即判断结果为0,~0得到全1的一个数,如果按%d输出为整型,则正好是-1。
-1的原码为1000 0000 0000 0000 0000 0000 0000 0001,
补码为符号位不变,其余位全部取反最后再加1,即
1111 1111 1111 1111 1111 1111 1111 1110+1得到
1111 1111 1111 1111 1111 1111 1111 1111
3.下面代码的输出为?
#include
#include
int main(void)
{
int a[100][200];
printf("%d", &a[37][45] - &a[0][3]);
return EXIT_SUCCESS;
}
输出:7442
分析:37*100+42,详细的参加指针的加减法。
4.下面代码的输出结果为?
#include
#include
int main(void)
{
int (*ptr)[5] = (int(*)[5]) 100;
printf("%d", (int) (&(*(ptr + 1))[2]));
return EXIT_SUCCESS;
}
输出:128
分析:ptr为数组指针,所以ptr+1即会往后指一个数组的长度,即到达100+5*sizeof(int)=120,然后取第二个单元的值,也就是再加上便宜2*sizeof(int)=8,最后得到128。
5.写一个“标准”宏MIN,这个宏输入两个参数并返回较小的一个。
#define MIN(A,B) ((A) <= (B) ? (A) : (B))
注意:括号是不能够缺少的,否则会产生边际效应。
6.定义一个宏把第二位清零,其余位取反
答案:#define NBL(a) (a) = (~(a)&~(1<<1))
7.写出以下程序的输出:
int i=-1;
printf("%d\n",i>>2)
分析:这是比较容易出错的地方,在C语言中左移也就是所说的逻辑移位,右端补0,而右移是算数移位,左端补齐的是最高位的符号位。这样的话,1左移31位的话就成了负的最大值。1>>2的结果就为0了,因为按照右移的规则,左端不停的补零,符号位依然为0,所以移的再多也是0。然而负数的移位需要注意:负数右移的终点就是-1,因为-1的二进制形式就是全1。而负数左移的可以达到负的最大值,因为这个时候除了符号位其它位都为0了。
答案:-1。
8.(a-b)*(c+5)的后缀表达式?
分析:后缀表达式也称逆波兰式,用户程序输入一个计算表达式之后,会首先被转换为逆波兰式,逆波兰式的计算对于计算机来说非常简单,详细的转换方法参见逆波兰式说明。
答案:a b - c 5 + *
9.给内存为0x XXXXXX的单元赋值为0
答案:*(char *)0xXXXXXX = 0;