- C语言基础考题(40)
选择题 20分每题2分
1、已知字母A的ASCII码为十进制数值65,且S为字符型,则执行语句S='A'+'6'-'3';后S中的值为 (B )
A.'D' B.68 C.不确定的值 D.'C'
2、若有定义语句:int a=12;,则执行语句:a+= a-= a*a;后,a的值是 (D )
A.264 B.552 C.144 D.-264
3、设有以下程序段int y;y=rand() % 30+1;则变量 y 的取值范围是 (A )
A.1<y<30 B.0≤y≤30 C.0<y≤30 D.1<y≤30
4、已知int x=10,y=20,z=30;以下语句执行后x,y,z的值是 (A )
if (x>y) z=x; x=y; y=z;
A.x=10,y=20,z=30 B.x=20,y=30,z=30 C.x=20,y=30,z=10 D.x=20,y=30,z=20
5.请读程序:
#define ADD(x) x+x
main()
{
int m=1,n=2,k=3;
int sum=ADD(m+n)*k;
printf("sum=%d",sum);
}
输出结果是 (D )
A.sum=9 B.sum=10 C.sum=12 D.sum=18
8.假设变量a,b均为整形,表达式(a=5,b=2,a>b?a++:b++.a+b)的值是 (A )
A.7 B.8 C.9 D.2
9.设有如下程序段,下面描述中正确的是 ( C)
int k=10;while(k=0)k=k-1;
- 循环执行一次 B.循环是无限循环 C.循环体语句一次也不执行 D.循环体语句执行一次
编程题20分每题10分
- 编写函数求1~100中奇数的平方与偶数的立方的和
#include <stido.h>
int main(int argc,const *argv[])
{
int i,ji,ou;
if(i=1;i<100;i++)
{
if(i%2==1)
{
ji=0+i*i;
}
if(i%2==0)
{
ou=ou+i*i;
}
}
sum=ji+ou;
printf(“sum=%d\n”,sum);
return 0;
}
填空
- char型数据在微机中储存值为0xc0,则printf以%d打印值为 -65
- char a=203;int b =a;int c = a&0xff ;b= -53 ;c= -53 ;
- linux下32位系统,char str = “hello”;char *p = str; int n = 10;
sizeof(str)= 7 ;sizeof (p)= ;sizeof (n)= 1 ;
- int a=1,b=2,c=3,d=4,m=2,n=2;执行(m=a>b)&&(n=c>d)后,n=0
单选
- 有以下程序段,执行后,mul的值为( B )
int a[ ] = {1,3,5,7,9};
int mul, *data , x;
mul = 1;
data = &a[1];
for(x=0; x<3; x++){
mul *= *(data+x);
}
printf(“%d\n”, mul);
- 945 B.315 C.105 D.15
- 以下语句不能正确赋值的是( C )
- char *s=" China" ;
- char s3[20]=" China" ;
- char s2[]={'C', 'h', 'i', 'n', 'a'};
- char s1[10]; s1=" China" ;
- 设有如下结构定义: struct student {int num; char name[20]; char sex; int age; char addr[30]; }stud; 若用printf( "%s\n" ,...)访问该结构中name值的正确方法是( )
- stud- > name
- &stud.name
- stud.&name
- stud.name
- 有以下程序段x=7执行后的值为( B )
int fun(int x) {
int p; if(x= =0 || x==1)
return(3);
p=x -fun(x- 2);
return p;
}
- 0 B. 2 C.5 D.6
- 假语句while(!E)中的表达式E等价于( A)
- E ==1 B. E != 0 C. E !=1 D. E==0
- 有以下程序端,int k=0; while(k=1) k++; 则while循环执行的次数是( D)
- 一次也不执行
- 执行1次
- 有语法错,不能执行
- 无数次
- 以下程序运行后,输出结果是( C )
main( )
{
char ch[2][5] = {“693”, “825”}; *p[2];
int i, j, s = 0;
for(i=0; i<2; i++) p[i] = ch[i]
for(i=0; i<2; i++)
for(j=0; p[i][j]>=’0’ && p[i][j] <=’9’; j+=2)
s=10*s+p[i][j]-‘0’;
printf(“%d\n”, s);
}
- 6385 B.33 C.693825 D.22
- 以下程序while循环的循环次数是( D )
main(){
int i=0;
while(i<10)
{
if(i<1)
continue,
if(i-=5) break;
i+ +:
}
}
- 死循环,不能确定次数
- 6
- 10
- 1
- 以下对妆举类型名的定义中正确的是( )
- enum a {"one”, "two', "thee”};
- enum a={"one', "two', "thee”};
- enum a {one=9, two=-1, three};
- enum a={one, two, three};
- 以下程序运行后,输出结果是(D ) int x=3, do{ print(%3d"; x =-2; } whlie(!(--x));
- 死循环
- 12
- 30
- 1
- 以下程序运行后,输出的结果是( )
main()
{
Char *s = “12134211”; int v[4] = {0,0,0,0}, k, i;
for(k=0; s[k]; k++){
switch(s[k]){
case ‘1’: i=0;
case ‘2’: i=1;
case ‘3’: i=2;
case ‘4’; i=3;
}
v[i]++;
}
for (k=0; k<4; k++) printf(“%d”, v[k]);
}
- 4 6 7 8
- 8 8 8 8
- 0 0 0 8
- 4 2 1 1
21. 假定有以下变量定义;int k=7, x=12;则能使值为3的表达式为( A)
A. (x%=k)-(k%=5)
B. x%=k-k%5
C. x%=(k-k%5)
D. x%=(k%=5)
22. 设有如下结构定义:struct student {char name[20]; char sex; int age; char addr[30];} studA, stud B; 若用把studA拷贝给studB正确的方法是( )
A. strcpy(studB, studA);
B. strcpy(studB, studA, sizeof(studA));
C. memcpy(studB, studA, sizeof(studA));
D. memcpy(&studB, &studA, sizeof(studA));
23. 想要对一个文件文件的尾部追加写入,应当在fopen语句中使用的文件操作方式指示符号为( )
A. r B. wb C. a D.w
24. 为了比较两个字符串s1和s2 是否相等,应当使用( D )
A. if(s1 == s2)
B. if(s1 = s2)
C. if(strcmp(&s1, &s2) == 0)
D. if(strcmp(s1, s2) == 0)
25. 有以下程序,程序运行后的输出结果是( )
#include
#include
main()
{
char* p = “abcde\0fghijk\0”;
printf(“%d\n”, strlen(p));
}
- 15 B. 6 C. 5 D.12
改错题
26. 如下程序中用于输出 “welcome home”。请指出其中的错误
void Test(void)
{
char pcArray[12];
strcpy(pcArray, “welcome home”);
printf(“%s!”, pcArray);
return;
}
1,头文件没有定义string,不能直接使用strcpy。
2,“welcome home”,无定义
3,%s后面的“i”意义不明。
编程题
- 宏定义,比较返回大的
- <stdio.h>与”stdio.h”的区别
- 数组里数,从小到大输出
- 仿写strcpy,有strcpy,
- 编译时<stdio.h>是编译软件按系统规定的标准方式检索文件目录;"stdio.h"则是先在源程序文件所在文件目录搜索需包含的文件,没找到再按系统规定的标准方式检索文件目录, 当所需文件不在源文件所属文件夹时后者慢一些。
2,
1.#include <stdio.h>
2.int main(int argc,const *argv[ ])
3.{
4. int a[10];
5. int i, j, t;
6. printf(“请输入10个数\n”);
scanf(“%s”, a[ j ] )
printf(“\n”);
for(i =0; i<10;i++)
{
for(j=0; j<9;j++)
{
if(a[ j]>a[j+1})
{
t=a[ j];
a[ j]=a[ j+1];
a[ j+1]=t;
}
}
}
printf(“%s”, a[ j ] )
return 0;
}
生活题(简答)
有层楼共100层,有两个完全一样的弹珠,都有相同的坚韧度,如何确定弹珠在哪一层会承受不住而崩碎
首先在50楼丢下一枚弹珠,碎了就拿另一个去25楼丢下去,如果没碎,就去75楼试一次;
如果没碎,拿这个弹珠去87楼试一次;