安徽c语言省二笔试题,习题二——C语言笔试题

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值