c面试题


1) 设x,y均为整型变量,且x=10 y=3,则以下C语言的输出结果是()。(选择一项)
printf(“%d,%d\n”,x–,–y);
a) 10,3
b) 9,3
c) 9,2
d) 10,2

2) 在C语言中,要计算一个数(变量i)的开平方,下面代码正确的是()。(选择一项)
a) printf(sqrt(t), “\n Square of%d”,i)
b) printf(“\n Square of %d is %d”,i,sqrt(i))
c) printf(sqrt(i),i,t, “\n Sqrt of %d is %d”)
d) printf(i,t,”\n Square of%d”)

e) scanf(i,”\n Square of%d is %d”,sqrt(i))

3) 运行下列C程序:
#include
void fun(int x,int y,int z)
{ z=x*x+y*y;}
void main()
{
int a=31;
fun(5,2,a);
printf(“%d”,a);
}
输出结果是()。(选择一项)
a) 0
b) 29
c) 31
d) 无定值

4) 在C语言中,下面选项()是合法的变量名。(选择两项)
a) Minimum
b) 3 rd_row
c) n1+n2;
d) Doubles
e) First.name

5) 运行下面的C程序:
#include
void main()
{
int n;
scanf(“%d”,&n);
if(n++<10)
printf(“%d\n”,n);
else
printf(“%d\n”,n--);
}
若从键盘上输入9,则输出结果是()。(选择一项)
a) 11
b) 10
c) 9
d) 8

6) 运行下面的C程序:
#include
void main()
{
int n;
scanf(“%d”,&n);
if(n++<10)
printf(“%d\n”,n);
else
printf(“%d\n”,n--);
}
若从键盘上输入9,则输出结果是()。(选择一项)
a) 11
b) 10
c) 9
d) 8

7) 在C语言中,当说明一个结构体变量时系统分配给它的内存是()(选择一项)
a) 各成员所需内存量的总和
b) 结构中第一个成员所需内存量
c) 成员中占内存量最大者所需的容量
d) 结构中最后一个成员所需的内存量

8) 在C语言中,下列关于条件语句的描述中,正确的是()。(选择两项)
a) 当if语句嵌套使用的时候,最后一个else和最近的一个没有else匹配的if匹配
b) 一个if可以有多个else与之匹配
c) 一个switch语句总是可以被一系列if…else语句替换
d) 当执行break语句时程序将停止执行

9) 在C语言中,下面不正确的字符串常量是()。(选择一项)
a) ‘abc’
b) “12’12”
c) “0”
d) “ ”
10) int a=4,b=20;
if (a>b && ++a
printf(“b=%d”,b)
else
printf(“a=%d”,a);
上面的C程序段的输出结果是()(选择一项)
a) b=20
b) a=5
c) a=4
d) b=21
11) 在C语言中,有如下定义
void f(int x,int y)
{
int t;
if(x
{t=x;x=y;y=t;}
}
main()
{
int a=4,b=3,c=5;
f(a,b);
f(a,c);
f(b,c);
printf(“%d,%d,%d\n”,a,b,c);
}
执行后输出的结果是()。(选择一项)
a) 3,4,5
b) 5,3,4
c) 5,4,3
d) 4,3,5

13) int a[5]={3,9,5,6,4};
printf(“%d”,*(a+4));
以上C程序段的输出结果是()。(选择一项)
a) 3
b) 5
c) 4
d) 6

14) 分析下面的C语言代码:
int a=1,b=10;
do{
b-=a; a++;
}while (b--<0);
则执行循环语句后b的值为()。(选择一项)
a) 9
b) –2
c) –1
d) 8
15) 设i是int型变量,f是float型变量,用下面的语句给这两个变量输入值:
scanf("i=%d,f=%f",&i,&f);
为了把100和765.12分别赋给i和f,则正确的输入为()。(选择一项)
a) 100 765.12
b) i=100,f=765.12
c) 100<回车> 765.12
d) x=100 y=765.12

16)在C语言中,下列()是合法的标识符。(选择两项)
a) COUNT
b) P234
c) 4x
e) short

17) 有数组int num [5] = {10,20,30,40,50};
num[3]的值为()。 (选择一项)
a) 30
b) 50
c) 40
d) 20
e) 10

18) #include
void main()
{
int a=3,b=2,c=1;
int x=10,y=20;
if(a
if(b!=0)
if(!x)
y=1;
else if(x)
y=0;
y=-1;
printf("%d",y);
}
上面的C程序的输出结果是()。(选择一项)
a) 20
b) 1
c) 0
d) -1

19) void main()
{
int i, x[3][3]={1,2,3,4,5,6,7,8,9};
for(i=0;i<3;i++)
printf("%d ",x[i][2-i]);
}
以上C程序的输出结果是()。(选择一项)
a) 1 5 9
b) 1 4 7
c) 3 5 7
e) 3 6 9

20) C语言中,while和do…while循环的主要区别是()。(选择一项)
a) while的循环控制条件比do…while的循环控制条件严格
b) do…while的循环体至少无条件执行一次
c) do…while允许从外部转到循环体内
d) do…while的循环体不能是复合语句

21) 执行下面的C程序段后,输出结果是()。(选择一项)
int a=5;
while( a--);
printf( "%d", a);

a) 54321
b) 4321
c) 0
d) -1

22) 以下正确的叙述有()。(选择两项)
a) 在C程序中,每行中只能写一条语句
b) 在C程序中,Abc和abc是2个相同的变量
c) 若a和b 的类型相同,在计算了赋值表达式a=b后b的值将放入a,而b的值不变
d) 若a是float型变量,a=10是合法的,因为float型变量允许存放整型数

23) 下面C代码的输出结果是()。(选择一项)
int answer,result;
answer=100;
result=answer-10;
printf(“The result is %d”, result+5);

a) The result is 90
b) The result is 95
c) The result is 10
d) The result is 100

24) char *p="happy new year";
char *q=p;
int k;
for( k=1;k<8;k++)
{
putchar(*q); //putchar函数用来输出单个字符
q++;
}
上面C程序段的输出结果是()。(选择一项)

a) happy new year
b) happy new
c) happy n
d) happy
e) appy n

25) 在C语言中,根据下面的定义,能打印出字母m的语句是()。(选择一项)
struct person{ char name[9]; int age; };
struct person per[10]={"john",17,
"paul",19,
"mary",18,
"adam",16};

a) printf("%c\n",per[3].name);
b) printf("%c\n",per[3].name[1]);
c) printf("%c\n",per[2].name[1]);
d) printf("%c\n",per[2].name[0]);

26) 在C语言中,存储类别定义了变量的()。(选择两项)
a) 生命周期
b) 可见性
c) 关系性

27) 在C语言中,设有数组定义: char array [ ]="China"; 则数组 array所占的空间为( )。(选择一项)
a) 4个字节
b) 5个字节
c) 6个字节
d) 7个字节

28) 在C语言中,()是在所有函数外部声明的。(选择一项)
a) 全局变量
b) 局部变量
c) 形参
29) 以下对C语言函数的有关描述中,正确的是()。(选择一项)
a) 调用函数时,只能把实参的值传送给形参,形参的值不能传送给实参
b) C函数既可以嵌套定义又可以递归调用
c) 函数必须有返回值,否则不能使用函数
d) C程序中有调用关系的所有函数必须放在同一个源程序文件中

30) 分析下面的C程序:
#include
void main()
{
int num=0;
while(num<=2){
num++;
printf("%d ",num);
}
}
输出结果是()。(选择一项)
a) 1 2 3
b) 0 1 2
c) 2 3
d) 1 2

31) 分析下面的程序:
void fun (int a,int b,int c)
{
a=456; b=567; c=678;
}
void main()
{
int x=10, y=20,z=30;
fun (x,y,z);
printf("%d,%d,%d\n",z,y,x);
}
输出结果是()。(选择一项)
a) 30,20,10
b) 10,20,30
c) 456,567,678
d) 678,567,456

32) 研究下面的C程序段:
int i,j;
for (i=5;i;i--)
for(j=0;j<4;j++){…}
循环体的总执行次数是()。(选择一项)
a) 20
b) 25
c) 24
d) 30
33) 设x,y,z,t均为int型变量,则执行以下语句后,t的值为()。
x=y=z=1;
t=++x||--y&&++z;(选择一项)
a) 不定值
b) 2
c) 1
d) 0

34) void fun(int *x, int *y) { *x=3; *y=4; }
void main()
{
int x=1,y=2;
printf("%d %d ",x, y);
fun(&y,&x);
printf("%d %d",x, y);
}
上面的C程序段的输出结果是()。(选择一项)
a) 2 1 4 3
b) 1 2 1 2
c) 1 2 4 3
d) 2 1 1 2

35) 分析下面的C语言程序:
#include
struct stu
{
int num;
char name[10];
int age;
};
void main()
{
struct stu students[3]= {{9801,”Zhang”,20},{9802,”Wang”,19},{9803,”Zhao”,18} };
printf(“%s\n”,(*(students+2)).name);
}
输出结果是()。(选择一项)
a) Zhang
b) Zhao
c) Wang
d) 18

36) 阅读下面的C语言代码,输出结果是()。
int x, y = 1, z=0;
if ( z < 0 )
x = 3;
else if ( y == 0 )
x = 5;
else
x = 7;
printf("%d, %d", x, y);(选择一项)
a) 7, 0
b) 7, 1
c) 3, 3
d) 以上都不正确

37) 要将20赋值到数组Num的第三个元素,正确的方法是()。(选择一项)
a) Num[3]=20
b) Num[2]=20
c) Num[4]=20
d) [3] Num=20

38) 在C语言中,已知字母A的ASCII码是65,则执行语句:char ch='A'+3; 后ch的值为( )。(选择一项)
a) 不能确定
b) 68
c) C
d) D

39) 在C语言中,以下所列的各函数首部中,正确的是( )。(选择一项)
a) void play(var :Integer,var b:Integer)
b) void play(int a,b)
c) void play(int a,int b)
d) Sub play(a as integer,b as integer)

40) C语言中,可以通过指针访问一个变量,表示指针的运算符是()。(选择一项)
a) &
b) *
c) ^
d) %
e) @

41) 下面的C程序段执行完后,x的值为( )。
int x=3, y=2;
x*=x+y;(选择一项)
a) 2
b) 10
c) 15
d) 3

42) 在C语言中,能正确表示a和b同时为正或同时为负的逻辑表达式是()。(选择一项)
a) (a>=0‖b>=0)&&(a<0‖b<0)
b) (a>=0&&b>=0)&&(a<0&&b<0)
c) (a+b>0)&&(a+b<=0)
d) a*b>0

43) 下面的C语言代码段的输出结果是()。(选择一项)
int j;
for(j=1; j<10; j+=2)
printf("%d ",j);

a) 1 2 3 4 5 6 7 8 9
b) 2 4 6 8
c) 1 3 5 7 9
d) 1 2 4 6 8

44) 用来将两个字符串合并为一个字符串的函数是()。(选择一项)
a) strcat()
b) strcpy()
c) strlen()

45) 在C语言中,表达式:10!=9 的值是()。(选择一项)
a) true
b) 非零值
c) 0
d) 1

46) 分析下面的C代码段:
char str1[15] = "Sea View";
char str2[15] = "Sea Breeze";
strcpy(str1,str2);
printf("%s\n",str1);
则输出结果是()。(选择一项)
a) Sea View
b) Sea Breeze
c) Sea View Sea Breeze
d) Sea Breeze Sea View

47) 在C语言中,下列正确的字符型常量是()。(选择一项)
a) “f ”
b) ‘9’
c) #
d) 365

48) 下面说法正确的是()。(选择三项)
1)C语言中for 循环可以重复执行操作
2)do 操作至少要执行一次
3)exit()函数会立即使程序结束

a) 1)和2)都是错误的
b) 1)是正确的
c) 2)是正确的
d) 3)是正确的

49) 在C语言中,以下不会出现死循环的语句是()。(选择一项)
a) int x=0;
do{x++;}while(x=1);
b) for(k=10; ; k--);
c)for(y=0, x=1; x>++y; x=k++) k=x;
d)while(1) {x++;}
50) 分析下面的C语言程序:
void main()
{
int a,b,c=246;
a=c/100%9;
b=(-1)&&(-1);
printf(“%d,%d\n”,a,b);
}
输出结果是()。(选择一项)
a) 2,1
b) 3,2
c) 4,3
d) 2,-1

52) 在C语言中,下面( )是逻辑运算符中优先级最高的。(选择一项)
a) !
b) &&
c) ||
d) |
e) &

53) 设P1和P2是指向同一个int型一维数组的指针变量,k为int型变量,则不能正确执行的语句是()。(选择一项)
a) k=*P1+*P2;
b) P2=k;
c) P1=P2;
d) k=(*P1) * (*P2);

55) 运行如下程序:
#include
void main()
{
int a=2,b=-1,c=2;
if(a
if(b<0)
c=0;
else
c++;
printf(“%d\n”,c);
}
输出结果为()。(选择一项)

a) 0
b) 3
c) 2
d) 4

56) 在C语言中,下列()是合法的标识符。(选择两项)
a) Minimum
b) 3rd_row
c) n1+n2
d) Doubles

57) #include
void change(int x)
{
x+=5;
}
void main()
{
int x=5;
change(x);
printf(“%d”, x);
}
上述C程序运行后会显示()。(选择一项)
a) 0
b) 5
c) 10
d) %d

58) 在C语言中,以下表达式计算结果是()。(选择一项)
15 + 80 / 2 * 10 – 12 * 2 / 3 – 10
a) 298
b) 553
c) 397
d) 507

59) 以下C语言代码的输出结果是( )。(选择一项)
#include
void main()
{
int a,b = 0;
int c[10] = {1,2,3,4,5,6,7,8,9,0};
for(a=0; a<10; ++a)
if((c[a] % 2)==1)
b = b + c[a];
printf("%d ", b);
}

a) 16
b) 45
c) 20
d) 25

60) 以下定义语句中,错误的是()。(选择一项)
a) int a[]={1,2};
b) char a[3]={ '1', '2', '3'};
c) char s[10]= "test";
d) int n=5,a[n];

61) 在C语言中,假定所有变量均为整型,则下列代码执行后c的值是()。(选择一项)
a=2; b=5; b++; c=a+b;
a) 2
b) 6
c) 7
d) 8

61) 在C语言中,假设,char w; int x; float y; double z;
则表达式:w*x+z-y值的数据类型为( )。(选择一项)
a) float
b) char
c) int
d) double
62) 下列C语言代码的输出是()。(选择一项)
void main()
{
int temp=10;
printf(“%d ”,temp++);
temp++;
printf(“%d”,temp);
}
a) 10 12
b) 11 12
c) 10 11
d) 以上都不是

64) 阅读下面的C语言代码,输出结果是( )。
int x, y = 1, z=0;
if ( z < 0 )
x = 3;
else if ( y == 0 )
x = 5;
else
x = 7;
printf("%d, %d", x, y);(选择一项)

a) 7, 0
b) 7, 1
c) 3, 3
d) 以上都不正确

65) 在C语言中,以下所列的各函数首部中,正确的是()。(选择一项)
a) void play(var :Integer,var b:Integer)
b) void play(int a,b)
c) void play(int a,int b)
d) Sub play(a as integer,b as integer)

66) C语言中,可以通过指针访问一个变量,表示指针的运算符是()。(选择一项)
a) &
b) *
c) ^
d) %
e) @

67) 若有说明:int a[10];则对a数组元素的正确引用是()。(选择两项)
a) a[10]
b) a[3+1]
c) a(5)
d) a[0]

68) 在C语言中,声明m,n为整型变量,p1,p2为整型指针,下列语句不正确的是()(选择三项)
a) p1=&m;
b) p2=n;
c) *p1=&n
d) p1=&p2;

69) #include
void main()
{
int a=97,c=65;
printf(“a=%c,c=%c\n”,a,c);
}
以上C程序的运行结果是()。(选择一项)
a) a=%a,c=%A
b) a=a,c=A
c) a=97,c=65
d) a=A,c=a

70) 任何整数与其本身进行“异或”运算的结果为()。(选择一项)
a) 0
b) 本身
c) 1
d) –1

71) 有如下C语言程序段:
int *p,a=10,b=1;
p=&a;
a=*p+b;
执行该程序段后,a的值为()。(选择一项)
a) 12
b) 11
c) 10
d) 编译出错

72) 在以下C代码执行后,*x的值是()。(选择一项)
int a=20,b=50;
int *x;
x=&a;
x=&b;
a) 20
b) 50
c) a
d) b

73) 在C语言中,‘19+12’在这里,19和12是()。‘+’是()。(选择一项)
a) 操作数,操作符
b) 操作符,操作数
c) 变量,操作数
d) 操作,操作数

74) 在C语言中,下列()是合法的标识符。(选择两项)
a) COUNT
b) P234
c) 4x
d) short

75) 在C语言中,有以下程序:
int*f(int*x,int*y)
{if(*x<*y)return x;
else return y;}
main(){
int a=7,b=8,*p,*q,*r;
p=&a;
q=&b;
r=f(p,q);
printf(“%d,%d,%d\n”,*p,*q,*r);}
执行后输出的结果是( )。(选择一项)
a) 7,8,8
b) 7,8,7
c) 8,7,7
d) 8,7,8

76) void main()
{
int i, x[3][3]={1,2,3,4,5,6,7,8,9};
for(i=0;i<3;i++)
printf("%d ",x[i][2-i]);
}
以上C程序的输出结果是( )。(选择一项)
a) 1 5 9
b) 1 4 7
c) 3 5 7
d) 3 6 9

77) (10*(2-8)+10)/(5-5*2)
在C语言中,上面的表达式计算结果为()。(选择一项)
a) –10
b) 10
c) 30
d) 32

78) 下面选项()是C语言中定义的循环语句类型。(选择两项)
a) if else
b) while
c) swich…case
d) for
e) repeat…until

79) int n=2;
while(n=0)
{
printf(“%d”,n);
n--;
}
在C语言中,上述循环体执行的次数是( ),(选择一项)
a) 0次
b) 1次
c) 2次
d) 无限次

80) 分析下面的C程序:
#include
void main()
{
int num=0;
while(num<=2){
num++;
printf("%d ",num);
}
}
输出结果是( )。(选择一项)
a) 1 2 3
b) 0 1 2
c) 2 3
d) 1 2

81) sub(int x,int y,int *z)
{
*z=y-x;
}
main()
{
int a,b,c;
sub(10,5,&a);
sub(7,a,&b);
sub(a,b,&c);
printf(“%d,%d,%d”,a,b,c);
}
在C语言中,以上程序的运行结果是( )。(选择一项)
a) 5,2,3
b) -5,-12,-17
c) 5,-2,-7
d) -5,-12,-7

84) 在C语言中,有以下程序:
main()
{
int x[8]={8,7,6,5,2,0},*s;
s=x+3;
printf(“%d\n”,s[2]);
}
执行后输出的结果是()。(选择一项)
a) 随机值
b) 0
c) 5
d) 6

86 )int a[2][3]={{4,5,6},{7,8,9}};
int*p[]={a[0],a[1]};
int m,n;
m=0;
for(n=0;n<3;n++)
printf(“a[%d][%d]=%d”,m,n,*(p[m]+n));
在C语言中,以上程序的输出结果,正确的是()。
(选择一项)
a) a[1][1]=4 a[2][2]=5 a[3][3]=6
b) a[0][0]=4 a[0][1]=5 a[0][2]=6
c) a[0][0]=7 a[0][1]=8 a[0][2]=9
d) a[1][1]=7 a[2][2]=8 a[3][3]=9

87) 在C语言中,以下不正确的叙述是()。(选择一项)
a) 在C程序的算术运算符中,取模(%)的优先级最高
b) 在C程序中,Aph和aph是两个不同的变量
c) 若a和b类型相同,在动行了赋值表达式a=b后,将b的值赋给a,而b的值不变
d) 当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值

88) 在C语言中,下面选项()声明一个数组用于保存4个参赛者参加5个不同项目的比赛成绩。(选择一项)
a) score[5][6]
b) score[4][5]
c) score[5][4]

89) 考虑以下的C程序:
#include
void main()
{
int i,j,num=0;
for(i=0;i<4;i++)
for(j=i;j<2;j++)
num=num+j;
printf("\nThe value of num is %d",num);
}
程序执行后,num的值应该是()。(选择一项)
a) 2
b) 4
c) 0
d) 3

91) 关于C语言中的函数,正确的是()。(选择两项)
a) 函数应该以它们调用的顺序来定义
b) return语句可以出现在函数的任何地方
c) 函数定义可以在主函数前面也可以出现在主函数后面
d) 每一个函数必须有一个return语句
e) 函数总是返回一个整型数据

93) 下面C语言代码的输出结果是()。(选择一项)
printf(“[%8.4s]”,”Hello world!”);
a) [Hello world!]
b) [Hell ]
c) [ Hell]
d) [Hello wo]

94) 研究如下C语言程序:
#include
void main()
{
int n=9;
while(n>6)
{
n–;
printf(“%d”,n);
}
}
输出结果是()。(选择一项)
a) 987
b) 8765
c) 876
d) 9876

95) 在C语言中,下面不能对字符串正确赋初值的语句是()。(选择一项)
a) char str[5]=”good!”;
b) char str[]=”good!”;
c) char *str=”good!”;
d) char str[5]={‘g’,’o’,’o’,’d’};

96) C语言中,可以用以下()退出循环,继续执行循环之后的语句。(选择一项)
a) break
b) loop
c) exit(0)
d) continue

97) 在C语言中,为一个特定的数据分配内存时,我们必须做()。(选择一项)
a) 定义一个特定数据类型的变量
b) 定义一个值
c) 定义一个特定数据类型的指针
d) 以上都不是

100) 在C语言中,下列对数组的声明中,非法的是()。(选择三项)
a) int score(100);
b) float values[10][15];
c) float average[ROW],[COLUMN];
d) char name[15];
e) int sum[];
101)在C语言中,有如下定义
main(){int i=0,s=0;
do{
if(i%2){i=i+2;}
i++;
s=s+i;}while(i<7);
printf("%d\n",s);
}
执行后输出的结果是( )。(选择一项)
a) 16
b) 12
c) 18
d) 21

102) 在C语言中,设有定义:
struct cust_type
{
char name[20]
float balance;
}cust;
FILE *fp
下列将变量cust以二进制形式保存到文件fp的语句正确的是()。(选择一项)
a)fwrite(cust,sizeof(struct cust_type),1,fp);
b)fwrite(&cust,sizeof(cust),1,fp);
c)fwrite(fp, sizeof(struct cust_type),1,cust);
d)fwrite(fp, sizeof(cust),1,&cust);
103) 在C语言中,判断char型变量ch是否为大写字母的正确逻辑表达式是()。(选择一项)
a) ‘A’<=ch<=’Z’
b) (ch>=’A’)‖(ch<=’Z’)
c) (ch>=’A’)&&(ch<=’Z’)
d) (‘A’<=ch)AND(‘Z’>=ch)

104) 在C语言中,用作计数器的变量通常是()。(选择两项)
a) 用在循环语句中
b) 用于保存循环中变量的总数量
c) 用于保存输入的数值
d) 用于记录循环被执行的次数

106) #include
void main()
{
int i=0, x=0;
do{
if(i%5 == 0)
x++;
++i;
}while(i<20);
printf("%d",x);
}
以上C语言代码的输出结果是( )。(选择一项)
a) 4
b)10
c)0
d) 以上都不是

107) 在C语言中,下列()格式用于在printf() 语句中以十六时制的格式显示变量的值。(选择一项)
a) %o
b)%x
c)%a
d)%octal
108) 研究下面C程序:
#include
void main()
{
int x;
scanf(“%d”,&x);
if(x–<5)
printf("%d",x);
else
printf("%d",x++);
}
运行后,如果键盘上输入5,则输出结果是()。(选择一项)
a)3
b)4
c)5
d)6

109) 研究下面的C语言代码:
#include
void main() {
int temp=10;
printf(“%d “,temp++);
temp++;
printf(“%d “, temp);}
输出是()。(选择一项)
a)10 12
b)11 12
c)10 11
d)以上都不是

110) 考虑以下的C程序:
#include
void main()
{
int i, j, num=0;
for(i=0;i<4;i++)
for(j=i;j<2;j++)
num=num+j;
printf("\nThe value of num is %d", num);
}
程序执行后,num的值应该是()。(选择一项)
a)2
b)4
c)0
d)3
111) 在C语言中,
描述A:'8' 与8是相同的
描述B:'$' 的数据类型是char
下面选项()描述是正确的。(选择一项)
a)两个描述都是正确的
b)两个描述都是错误的
c)只有描述A是正确的
d)只有描述B是正确的

112) 下列C语言程序段不是死循环的是()。(选择一项)
a) int i=100;
while(1)
{i=i%100+1;
if(i>100)
break;}
b) for(; ; );
c) int k=0;
do
{++k;}
while(k<=0);
d)int s=36;
while(s);

113) #include
void fun(int *x,int *y)
{
printf(“%d %d “, *x, *y);
*x=3;
*y=4;
}
void main(){
int x=1, y=2;
fun(&y, &x);
printf(“%d %d”, x, y);
}
以上程序段的输出结果是( )。(选择一项)
a)2 1 4 3
b)1 2 1 2
c)1 2 3 4
d)2 1 3 4

114) #include
void main() {
double x, y;
x=2;
y=x+3/2;
printf(“%f”,y); }
编译运行以上C语言中,输出结果应该为()。(选择一项)
a)3.500000
b)3
c)2.000000
d)3.000000

115)#include
void change(int x)
{
x+=5;
}
void main() {
int x=5;
change(x);
printf(“%d”, x); }
上述C程序运行后会显示()。(选择一项)
a) 0
b) 5
c) 10
d) %d
116) 考虑以下的C程序:
#include
void main()
{
int i, j, num=0;
for(i=0;i<4;i++)
for(j=i;j<2;j++)
num=num+j;
printf("\nThe value of num is %d", num);
}
程序执行后,num的值应该是( )。(选择一项)
a) 2
b) 4
c) 0
d) 3

117) 在C语言中,以下对结构体的定义不正确的是()。(选择一项)
a) typedef struct aa{
int a;
float b;
} AA;
AA xx;
b) struct aa,AA{
int a;
float b;}
c) struct {
int a;
float b;
} AA;
struct AA xx;
d) struct {
int a;
float b;};
118) 运行下列C程序:
#include
void fun(int x,int y,int z)
{ z=x*x+y*y;}
void main()
{
int a=31;
fun(5,2,a);
printf(“%d”,a);
}
输出结果是()。(选择一项)
a) 0
b) 29
c) 31
d) 无定值

119) 运行下面的C程序:
#include
void main()
{
int n;
scanf(“%d”,&n);
if(n++<10)
printf(“%d\n”,n);
else
printf(“%d\n”,n--);
}
若从键盘上输入9,则输出结果是()。(选择一项)
a) 11
b) 10
c) 9
d) 8

120) int a=4,b=20;
if (a>b && ++a
printf(“b=%d”,b)
else
printf(“a=%d”,a);
上面的C程序段的输出结果是()(选择一项)
a) b=20
b) a=5
c) a=4
d) b=21

121) 在C语言中,有如下定义
void f(int x,int y)
{
int t;
if(x
{t=x;x=y;y=t;}
}
main()
{
int a=4,b=3,c=5;
f(a,b);
f(a,c);
f(b,c);
printf(“%d,%d,%d\n”,a,b,c);
}
执行后输出的结果是()。(选择一项)
a) 3,4,5
b) 5,3,4
c) 5,4,3
d) 4,3,5

122) 考虑以下的C程序:
#include
void main()
{
int i,j,num=0;
for(i=0;i<4;i++)
for(j=i;j<2;j++)
num=num+j;
printf("\nThe value of num is %d",num);
}
程序执行后,num的值应该是()。(选择一项)
a) 2
b) 4
c) 0
d) 3

123) 关于C语言中的函数,正确的是()。(选择两项)
a) 函数应该以它们调用的顺序来定义
b) return语句可以出现在函数的任何地方
c) 函数定义可以在主函数前面也可以出现在主函数后面
d) 每一个函数必须有一个return语句
e) 函数总是返回一个整型数据

124) 运行如下程序:
#include
void main()
{
int a=2,b=1,c=2;
if(a
if(b<0)
c=0;
else
c++;
printf("%d\n",c);
}
输出结果为()。(选择一项)
a) 0
b) 3
c) 2
d) 4

125) 在C语言中,下面不能对字符串正确赋初值的语句是()。(选择一项)
a) char str[5]=”good!”;
b) char str[]=”good!”;
c) char *str=”good!”;
d) char str[5]={‘g’,’o’,’o’,’d’};

126) 在C语言中,假设
char w;
int x;
float y;
double z;
则表达式:w*x+z-y值的数据类型为()。(选择一项)
a) float
b) char
c) int
d) double

127) 仔细阅读下成的C语言代码:
void main()
{
int varl=3,var2=4,*ptr;
ptr=&varl;
var2=*ptr
printf(“%d”,var2);
}
变量var2的最后的值是()。(选择一项)
a) 3
b) 34
c) 4
d) varl在内存中的地址

128) 在C语言中,有如下定义
main()
{int i=0,s=0;
do{
if(i%1){i=i+2;}
i++;
s=s+i;}
while(i<7);
printf(“%d\n”,s);}
执行后输出的结果是()。(选择一项)
a) 16
b) 12
c) 28
d) 21

129) 在C语言中,有以下程序:
main()
{
int x[8]={8,7,6,5,0},*s;
s=x+3;
printf(“%d\n”,s[2]);
}
执行后输出的结果是( )。(选择一项)
a) 随机值
b) 0
c) 5
d) 6
130) main()
{int x,y;
scanf(“%d”,&x);
scanf(“%d”,&y);
if(x>y){x+=y;y++;}
else y+=x; x++;
printf(“%d,%d”,x,y);
}
在C语言中,对上面的程序,正确的叛断是()。
(选择一项)
a) 若输入数据1和4,则输出2和6
b) 若输入数据4和1,则输出6和2
c) 若输入数据4和4,则输出5和8
d) 有语法错误,不能通过编译
131)

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
doc格式,60多页吧,几百道题吧,都有答案吧,看好在下!部分:1.求下面函数的返回值(微软)int func(x) { int countx = 0; while(x) { countx ++; x = x&(x-1); } return countx; } 假定x = 9999。 答案:8思路:将x转化为2进制,看含有的1的个数。2. 什么是“引用”?申明和使用“引用”要注意哪些问题?答:引用就是某个目标变量的“别名”(alias),对应用的操作与对变量直接操作效果完全相同。申明一个引用的时候,切记要对其进行初始化。引用声明完毕后,相当于目标变量名有两个名称,即该目标原名称和引用名,不能再把该引用名作为其他变量名的别名。声明一个引用,不是新定义了一个变量,它只表示该引用名是目标变量名的一个别名,它本身不是一种数据类型,因此引用本身不占存储单元,系统也不给引用分配存储单元。不能建立数组的引用。3. 将“引用”作为函数参数有哪些特点?(1)传递引用给函数与传递指针的效果是一样的。这时,被调函数的形参就成为原来主调函数中的实参变量或对象的一个别名来使用,所以在被调函数中对形参变量的操作就是对其相应的目标对象(在主调函数中)的操作。(2)使用引用传递函数的参数,在内存中并没有产生实参的副本,它是直接对实参操作;而使用一般变量传递函数的参数,当发生函数调用时,需要给形参分配存储单元,形参变量是实参变量的副本;如果传递的是对象,还将调用拷贝构造函数。因此,当参数传递的数据较大时,用引用比用一般变量传递参数的效率和所占空间都好。(3)使用指针作为函数的参数虽然也能达到与使用引用的效果,但是,在被调函数中同样要给形参分配存储单元,且需要重复使用"*指针变量名"的形式进行运算,这很容易产生错误且程序的阅读性较差;另一方面,在主调函数的调用点处,必须用变量的地址作为实参。而引用更容易使用,更清晰。4. 在什么时候需要使用“常引用”? 如果既要利用引用提高程序的效率,又要保护传递给函数的数据不在函数中被改变,就应使用常引用。常引用声明方式:const 类型标识符 &引用名=目标变量名;例1int a ;const int &ra=a;ra=1; //错误a=1; //正确 例2string foo( );void bar(string & s); 那么下面的表达式将是非法的:bar(foo( ));bar("hello world"); 原因在于foo( )和"hello world"串都会产生一个临时对象,而在C++中,这些临时对象都是const类型的。因此上面的表达式就是试图将一个const类型的对象转换为非const类型,这是非法的。引用型参数应该在能被定义为const的情况下,尽量定义为const 。5. 将“引用”作为函数返回值类型的格式、好处和需要遵守的规则?格式:类型标识符 &函数名(形参列表及类型说明){ //函数体 }好处:在内存中不产生被返回值的副本;(注意:正是因为这点原因,所以返回一个局部变量的引用是不可取的。因为随着该局部变量生存期的结束,相应的引用也会失效,产生runtime error!注意事项:(1)不能返回局部变量的引用。这条可以参照Effective C++[1]的Item 31。主要原因是局部变量会在函数返回后被销毁,因此被返回的引用就成为了"无所指"的引用,程序会进入未知状态。 (2)不能返回函数内部new分配的内存的引用。这条可以参照Effective C++[1]的Item 31。虽然不存在局部变量的被动销毁问题,可对于这种情况(返回函数内部new分配内存的引用),又面临其它尴尬局面。例如,被函数返回的引用只是作为一个临时变量出现,而没有被赋予一个实际的变量,那么这个引用所指向的空间(由new分配)就无法释放,造成memory leak。(3)可以返回类成员的引用,但最好是const。这条原则可以参照Effective C++[1]的Item 30。主要原因是当对象的属性是与某种业务规则(business rule)相关联的时候,其赋值常常与某些其它属性或者对象的状态有关,因此有必要将赋值操作封装在一个业务规则当中。如果其它对象可以获得该属性的非常量引用(或指针),那么对该属性的单纯赋值就会破坏业务规则的完整性。(4)流操作符重载返回值申明为“引用”的作用:流操作符<>,这两个操作符常常希望被连续使用,例如:cout << "hello" << endl; 因此这两个操作符的返回值应该是一个仍然支持这两个操作符的流引用。可选的其它方案包括:返回一个流对象和返回一个流对象指针。但是对于返回一个流对象,程序必须重新(拷贝)构造一个新的流对象,也就是说,连续的两个<<操作符实际上是针对不同对象的!这无法让人接受。对于返回一个流指针则不能连续使用<<操作符。因此,返回一个流对象引用是惟一选择。这个唯一选择很关键,它说明了引用的重要性以及无可替代性,也许这就是C++语言中引入引用这个概念的原因吧。 赋值操作符=。这个操作符象流操作符一样,是可以连续使用的,例如:x = j = 10;或者(x=10)=100;赋值操作符的返回值必须是一个左值,以便可以被继续赋值。因此引用成了这个操作符的惟一返回值选择。例3#i nclude int &put(int n);int vals[10];int error=-1;void main(){put(0)=10; //以put(0)函数值作为左值,等价于vals[0]=10; put(9)=20; //以put(9)函数值作为左值,等价于vals[9]=20; cout<<vals[0]; cout<<vals[9];} int &put(int n){if (n>=0 && n<=9 ) return vals[n]; else { cout<<"subscript error"; return error; }} (5)在另外的一些操作符中,却千万不能返回引用:+-*/ 四则运算符。它们不能返回引用,Effective C++[1]的Item23详细的讨论了这个问题。主要原因是这四个操作符没有side effect,因此,它们必须构造一个对象作为返回值,可选的方案包括:返回一个对象、返回一个局部变量的引用,返回一个new分配的对象的引用、返回一个静态对象引用。根据前面提到的引用作为返回值的三个规则,第2、3两个方案都被否决了。静态对象的引用又因为((a+b) == (c+d))会永远为true而导致错误。所以可选的只剩下返回一个对象了。6. “引用”与多态的关系?引用是除指针外另一个可以产生多态效果的手段。这意味着,一个基类的引用可以指向它的派生类实例。例4Class A; Class B : Class A{...}; B b; A& ref = b;7. “引用”与指针的区别是什么?指针通过某个指针变量指向一个对象后,对它所指向的变量间接操作。程序中使用指针,程序的可读性差;而引用本身就是目标变量的别名,对引用的操作就是对目标变量的操作。此外,就是上面提到的对函数传ref和pointer的区别。8. 什么时候需要“引用”?流操作符<>、赋值操作符=的返回值、拷贝构造函数的参数、赋值操作符=的参数、其它情况都推荐使用引用。以上 2-8 参考:http://blog.csdn.net/wfwd/archive/2006/05/30/763551.aspx9. 结构与联合有和区别?1. 结构和联合都是由多个不同的数据类型成员组成, 但在任何同一时刻, 联合中只存放了一个被选中的成员(所有成员共用一块地址空间), 而结构的所有成员都存在(不同成员的存放地址不同)。 2. 对于联合的不同成员赋值, 将会对其它成员重写, 原来成员的值就不存在了, 而对于结构的不同成员赋值是互不影响的。10. 下面关于“联合”的题目的输出?a)#i nclude union{int i;char x[2];}a;void main(){a.x[0] = 10; a.x[1] = 1;printf("%d",a.i);}答案:266 (低位低地址,高位高地址,内存占用情况是Ox010A)………………
c面试题 4. static有什么用途?(请至少说明两种) 1.限制变量的作用域 2.设置变量的存储域 7. 引用与指针有什么区别? 1) 引用必须被初始化,指针不必。 2) 引用初始化以后不能被改变,指针可以改变所指的对象。 2) 不存在指向空值的引用,但是存在指向空值的指针。 8. 描述实时系统的基本特性 在特定时间内完成特定的任务,实时性与可靠性 9. 全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 全局变量储存在静态数据库,局部变量在堆栈 10. 什么是平衡二叉树? 左右子树都是平衡二叉树且左右子树的深度差值的绝对值不大于1 11. 堆栈溢出一般是由什么原因导致的? 没有回收垃圾资源 12. 什么函数不能声明为虚函数? constructor 13. 冒泡排序算法的时间复杂度是什么? O(n^2) 14. 写出float x 与“零值”比较的if语句。 if(x>0.000001&&x<-0.000001) 16. Internet采用哪种网络协议?该协议的主要层次结构? tcp/ip 应用层/传输层/网络层/数据链路层/物理层 17. Internet物理地址和IP地址转换采用什么协议? ARP (Address Resolution Protocol)(地址解析協議) 18.IP地址的编码分为哪俩部分? IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。 2.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。写出C程序。 循环链表,用取余操作做 3.不能做switch()的参数类型是: switch的参数不能为实型。 華為 1、局部变量能否和全局变量重名? 答:能,局部会屏蔽全局。要用全局变量,需要使用"::" 局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内 2、如何引用一个已经定义过的全局变量? 答:extern 可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个变写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错 3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么? 答:可以,在不同的C文件中以static形式来声明同名全局变量。 可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错 4、语句for( ;1 ;)有什么问题?它是什么意思? 答:和while(1)相同。 5、do……while和while……do有什么区别? 答:前一个循环一遍再判断,后一个判断以后再循环 6、请写出下列代码的输出内容 #include<stdio.h> main() { int a,b,c,d; a=10; b=a++; c=++a; d=10*a++; printf("b,c,d:%d,%d,%d",b,c,d); return 0; } 答:10,12,120 1、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别? 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。这两者在存储方式上并无不同。这两者的区别虽在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。而静态全局变量则限制了其作用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。 从以上分析可以看出,把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的作用域,限制了它的使用范围。 static函数与普通函数作用域不同。仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数的源文件要包含这个头文件 static全局变量与普通的全局变量有什么区别:static全局变量只初使化一次,防止在其他文件单元中被引用; static局部变量和普通局部变量有什么区别:static局部变量只被初始化一次,下一次依据上一次结果值; static函数与普通函数有什么区别:static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝 2、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区)中,动态申请数据存在于(堆)中。 3、设有以下说明和定义: typedef union {long i; int k[5]; char c;} DATE; struct data { int cat; DATE cow; double dog;} too; DATE max; 则语句 printf("%d",sizeof(struct date)+sizeof(max));的执行结果是:___52____ 答:DATE是一个union, 变量公用空间. 里面最大的变量类型是int[5], 占用20个字节. 所以它的大小是20 data是一个struct, 每个变量分开占用空间. 依次为int4 + DATE20 + double8 = 32. 所以结果是 20 + 32 = 52. 当然...在某些16位编辑器下, int可能是2字节,那么结果是 int2 + DATE10 + double8 = 20 4、队列和栈有什么区别? 队列先进先出,栈后进先出 5、写出下列代码的输出内容 #include<stdio.h> int inc(int a) { return(++a); } int multi(int*a,int*b,int*c) { return(*c=*a**b); } typedef int(FUNC1)(int in); typedef int(FUNC2) (int*,int*,int*); void show(FUNC2 fun,int arg1, int*arg2) { INCp=&inc; int temp =p(arg1); fun(&temp,&arg1, arg2); printf("%d"n",*arg2); } main() { int a; show(multi,10,&a); return 0; } 答:110 7、请找出下面代码中的所以错误 说明:以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba” 1、#include"string.h" 2、main() 3、{ 4、 char*src="hello,world"; 5、 char* dest=NULL; 6、 int len=strlen(src); 7、 dest=(char*)malloc(len); 8、 char* d=dest; 9、 char* s=src[len]; 10、 while(len--!=0) 11、 d++=s--; 12、 printf("%s",dest); 13、 return 0; 14、} 答: 方法1: int main(){ char* src = "hello,world"; int len = strlen(src); char* dest = (char*)malloc(len+1);//要为"0分配一个空间 char* d = dest; char* s = &src[len-1];//指向最后一个字符 while( len-- != 0 ) *d++=*s--; *d = 0;//尾部要加"0 printf("%s"n",dest); free(dest);// 使用完,应当释放空间,以免造成内存汇泄露 return 0; } 方法2: #include <stdio.h> #include <string.h> main() { char str[]="hello,world"; int len=strlen(str); char t; for(int i=0; i<len/2; i++) { t=str[i]; str[i]=str[len-i-1]; str[len-i-1]=t; } printf("%s",str); return 0; } 1.-1,2,7,28,,126请问28和126中间那个数是什么?为什么? 第一题的答案应该是4^3-1=63 规律是n^3-1(当n为偶数0,2,4) n^3+1(当n为奇数1,3,5) 答案:63 2.用两个栈实现一个队列的功能?要求给出算法和思路! 设2个栈为A,B, 一开始均为空. 入队: 将新元素push入栈A; 出队: (1)判断栈B是否为空; (2)如果不为空,则将栈A中所有元素依次pop出并push到栈B; (3)将栈B的栈顶元素pop出; 这样实现的队列入队和出队的平摊复杂度都还是O(1), 比上面的几种方法要好。3.在c语言库函数中将一个字符转换成整型的函数是atool()吗,这个函数的原型是什么? 函数名: atol 功能: 把字符串转换成长整型数 用法: long atol(const char *nptr); 程序例: #include <stdlib.h> #include <stdio.h> int main(void) { long l; char *str = "98765432"; l = atol(lstr); printf("string = %s integer = %ld"n", str, l); return(0); } 2.对于一个频繁使用的短小函数,在C语言中应用什么实现,在C++中应用什么实现? c用宏定义,c++用inline 3.直接链接两个信令点的一组链路称作什么? PPP点到点连接 4.接入网用的是什么接口? 5.voip都用了那些协议? 6.软件测试都有那些种类? 黑盒:针对系统功能的测试白合:测试函数功能,各函数接口 7.确定模块的功能和模块的接口是在软件设计的那个队段完成的? 概要设计阶段 8.enum string { x1, x2, x3=10, x4, x5, }x; 问x= 0x801005,0x8010f4 ; 9.unsigned char *p1; unsigned long *p2; p1=(unsigned char *)0x801000; p2=(unsigned long *)0x810000; 请问p1+5= ; p2+5= ; 三.选择题: 1.Ethternet链接到Internet用到以下那个协议? A.HDLC;B.ARP;C.UDP;D.TCP;E.ID 2.属于网络层协议的是: A.TCP;B.IP;C.ICMP;D.X.25 3.Windows消息调度机制是: A.指令队列;B.指令堆栈;C.消息队列;D.消息堆栈; 4.unsigned short hash(unsigned short key) { return (key>>)%256 } 请问hash(16),hash(256)的值分别是: A.1.16;B.8.32;C.4.16;D.1.32 四.找错题: 1.请问下面程序有什么错误? int a[60][250][1000],i,j,k; for(k=0;k<=1000;k++) for(j=0;j<250;j++) for(i=0;i<60;i++) a[i][j][k]=0; 把循环语句内外换一下 2.#define Max_CB 500 void LmiQueryCSmd(Struct MSgCB * pmsg) { unsigned char ucCmdNum; ...... for(ucCmdNum=0;ucCmdNum<Max_CB;ucCmdNum++) { ......; } 死循环 3.以下是求一个数的平方的程序,请找出错误: #define SQUARE(a)((a)*(a)) int a=5; int b; b=SQUARE(a++); 4.typedef unsigned char BYTE int examply_fun(BYTE gt_len; BYTE *gt_code) { BYTE *gt_buf; gt_buf=(BYTE *)MALLOC(Max_GT_Length); ...... if(gt_len>Max_GT_Length) { return GT_Length_ERROR; } ....... } 五.问答题: 1.IP Phone的原理是什么? IPV6 2.TCP/IP通信建立的过程怎样,端口有什么作用? 三次握手,确定是哪个应用程序使用该协议 3.1号信令和7号信令有什么区别,我国某前广泛使用的是那一种? 4.列举5种以上的电话新业务?

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值