C语言基础考察
下面程序的输出是什么?你是不是一眼就能看出来呢???
考察c语言的基本功。
1.
[cpp] #include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
using namespace std;
int main()
{
int a = 2, b = 7, c = 5;
switch(a > 0)
{
case 1: switch(b < 0)
{
case 1 : printf("@"); break;
case 2 : printf("!"); break;
}
case 0: switch(c == 5)
{
case 1: printf("*"); break;
case 2: printf("#"); break;
default: printf("#"); break;
}
default: printf("&");
}
printf("\n");
return 0;
}
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
using namespace std;
int main()
{
int a = 2, b = 7, c = 5;
switch(a > 0)
{
case 1: switch(b < 0)
{
case 1 : printf("@"); break;
case 2 : printf("!"); break;
}
case 0: switch(c == 5)
{
case 1: printf("*"); break;
case 2: printf("#"); break;
default: printf("#"); break;
}
default: printf("&");
}
printf("\n");
return 0;
}
答案是:
*&
因为a>0,进入case 1,发现b<0为false,应该进入0,但是没有,退出这个switch,但是case1没有break,只能进入case0,满足条件后输出*,同样没有break退出,进入default后输出&退出。
2.
[cpp] #include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
using namespace std;
int i = 0;
int fun1(int i)
{
i = (i % i) * (i * i) / (2 * i) + 4;
printf("i = %d\n", i);
return (i);
}
int fun2(int i)
{
i = i <= 2 ? 5 : 0;
return (i);
}
int main()
{
int i = 5;
fun2(i / 2); printf("i = %d\n", i);
fun2(i = i / 2); printf("i = %d\n", i);
fun2(i / 2); printf("i = %d\n", i);
fun1(i / 2); printf("i = %d\n", i);
return 0;
}
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
using namespace std;
int i = 0;
int fun1(int i)
{
i = (i % i) * (i * i) / (2 * i) + 4;
printf("i = %d\n", i);
return (i);
}
int fun2(int i)
{
i = i <= 2 ? 5 : 0;
return (i);
}
int main()
{
int i = 5;
fun2(i / 2); printf("i = %d\n", i);
fun2(i = i / 2); printf("i = %d\n", i);
fun2(i / 2); printf("i = %d\n", i);
fun1(i / 2); printf("i = %d\n", i);
return 0;
}
答案:
5,2,2,4,2
解析:
知识点:1.函数都是值传递,所以不会改变外部i的值。2.全局变量和局部变量符合就近原则。
所以第一次i=5
然后i=5/2=2
但是进入之后经过层层运算后,里面的i变化,但是返回的时候i就释放掉,对原来的i没有影响。所以i=2
第三次i=2
第四次,进入函数后根据就近原则i相当于局部变量,局部变量为4,所以输出4,但是到printf时,i还是main里面的i,与刚才在函数中的i无关,所以还是2
摘自 飘过的小牛
上一篇: 国内云计算发展格局:晚起快进 多阵营角逐
下一篇: 中国云计算时代的开源:趋势启示录