二级C语言2010年培训
B)for(i=0;t[i]=s[i];i++);
C)do{*t++=*s++;}while(*s); D)for(i=0,j=0;t[i++]=s[j++];);
答案:C 解析 : while(*s)括号中最后一个字符为’\\0’,循环结束,少复制’\\0’不完整。 (33)有以下程序( strcat函数用以连接两个字符串) #include<stdio.h> #include<string .h> main()
{char a[20]=”ABCD\0EFG\0”,b[]=”IJK”; strcat(a,b);printf(”%s\\n”,a); }
程序运行后的输出结果是 A)ABCDE\\OFG\\OIJK B)ABCDIJK C)IJK D)EFGIJK
答案:B 解析: strcat(a,b)是把字符串b接中a的后面覆盖结束标志’\\0’,结尾添加’\\0’
(34)有以下程序,程序中库函数islower (ch)用以判断ch中的字母是否为小写字母 #include<stdio.h> #include<ctype.h> void fun(char*p) {int i=0; while (p[i])
{if(p[i]==’ ’&& islower(p「i-1」))p[i-1]=p[i-1]-‘a’+‘A’; i++; } }
main()
{char s1[100]=”ab cd EFG!”; fun(s1); printf(”%s\\n”,s1); }
程序运行后的输出结果是 A)ab cd EFG! B)Ab Cd EFg! C)aB cD EFG! D)ab cd EFg!
答案:C 解析: islower判断字符是否小写,非0(真)表示小写,语句p[i-1]=p[i-1]-‘a’+‘A’; 的作用是把小写转化为大写。由条件p[i]==’ ’&& islower(p「i-1」)知只有空格前一个字符 是小写时,才执行小写变大写,选C
(35)有以下程序 #include<stdio.h>
二级C语言2010年培训
void fun(int x)
{if(x/2>1)fun(x/2); printf(”%d”,x); }
main() {fun(7);printf(”\\n”);} 程序运行后的输出结果是 A)1 3 7 B)7 3 1 C)7 3 D)3 7
答案:D 解析:递归调用,第1次调用,条件7/2>1,执行第2次递归调用,3/2取整为1不大
于1,停止递归调用,执行后面的打印出3,后返回调用处,再招行打印语句输出7.
(36)有以下程序 #include<stdio.h> int fun()
{static int x=1; x+=1;return x; }
main() {int i;s=1;
for(i=1;i<=5;i++)s+=fun(); printf(”%d\n”,s); }
程序运行后的输出结果是 A)11 B)21 C)6 D)120
答案:B 解析:x为静态局部变量,x经过5次循环1,2,3,4,5对应的S累加和为:
3,6,10,15,21,最后输出21.
(37)有以下程序 #inctude<stdio.h> #include<stdlib.h> Main()
{int *a,*b,*c;
a=b=c=(int*)malloc(sizeof(int)); *a=1;*b=2,*c=3; a=b;
printf(“%d,%d,%d\n”,*a,*b,*c); }
程序运行后的输出结果是
二级C语言2010年培训
A)3,3,3 B)2,2,3 C)1,2,3 D)1,1,3
答案:A 解析:系统只为三个指针分配了一个整型数据的空间,最后指针C把数据3写入
该空间,所以选A
(38)有以下程序 #include<stdio.h> main()
{int s,t,A=10;double B=6; s=sizeof(A);t=sizeof(B); printf(“%d,%d\n”,s,t); }
在VC6平台上编译运行,程序运行后的输出结果是 A)2,4 B)4,4 C)4,8 D)10,6
答案:C 解析:sizeof返回对象或类型所占的内存字节,V C6中整型占4个字节,双精度 占8个字节
(39)若有以下语句 Typedef struct S {int g; char h;}T; 以下叙述中正确的是
A)可用S定义结构体变量 B)可用T定义结构体变量 C)S是struct类型的变量 D)T是struct S类型的变量
答案:B 解析:考查结构体定义,T已经是结构体类型名,不是变量
(40)有以下程序 #include<stdio.h> main()
{short c=124; c=c_______;
printf(“%d\n”、C); }
若要使程序的运行结果为248,应在下划线处填入的是 A)>>2 B)|248 C)&0248 D)<
答案:D 解析:左移1位表示放大2倍,右移一位缩小2倍,短整型总共占16位
二、填空题(每空2分,共30分)
请将每空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。
(1)一个栈的初始状态为空。首先将元素5,4,3,2,1依次入栈,然后退栈一次,再将元素 A,B,C,D依次入栈,之后将所有元素全部退栈,则所有元素退栈(包括中间退栈的元素)的顺序为【1】 解答:1DCBA2345 栈的性质:先进后出,后进先出
二级C语言2010年培训
(2)在长度为n的线性表中,寻找最大项至少需要比较【2】次。 解答:如果已经按从大到小排序,则只需比较1次就可以找到最大项
(3)一棵二叉树有10个度为1的结点,7个度为2的结点,则该二叉树共有【3】个结点。 解答:25个,根据性质3:度为0的节点个数是度为2的节点个数+1,全部的节点个数为:
8+10+7=25
(4)仅由顺序、选择(分支)和重复(循环)结构构成的程序是【4】程序。 解答:结构化程序
(5)数据库设计的四个阶段是:需求分析,概念设计,逻辑设计【5】。 解答:物理设计
(6)以下程序运行后的输出结果是【6】。 #include<stdio.h> main()
{int a=200,b=010;
printf(”%d%d\\n”,a,b); }
解答:2008
B=010是八进制,输出十进制为8
(7)有以下程序 #include<stdio.h> main() {int x,Y;
scanf(”%2d%ld”,&x,&y);printf(”%d\n”,x+y); }
程序运行时输入:1234567程序的运行结果是【7】。 解答:15 ,-得到x=12,得到y=3,所以x+y=15
(8)在C语言中,当表达式值为0时表示逻辑值“假”,当表达式值为【8】时表示逻辑值“真”。 解答: 非0,表示逻辑真
(9)有以下程序 #include<stdio.h> main()
{int i,n[]={0,0,0,0,0}; for (i=1;i<=4;i++)
{n[i]=n[i-1]*3+1; printf(”%d \);} }
程序运行后的输出结果是【9】。 解答: 1,4,13,40
二级C语言2010年培训
(10)以下fun函数的功能是:找出具有N个元素的一维数组中的最小值,并作为函数值返回。请填空。(设N已定义) int fun(int x[N]) {int i,k=0;
for(i=0;i (11)有以下程序 #include<stdio.h> int*f(int *p,int*q); main() {int m=1,n=2,*r=&m; r=f(r,&n);printf(”%d\n”,*r); } int*f(int *p,int*q) {return(*p>*q)?p:q;} 程序运行后的输出结果是【11】 解答:2 ,根据条件return(*p>*q)?p:q;返回指针p,q所指元素较大的地址 (12)以下fun函数的功能是在N行M列的整形二维数组中,选出一个最大值作为函数值返回,请填空。(设M,. N已定义) int fun(int a[N][M)) {int i,j,row=0,col=0; for(i=0;i 解答:a[row][col] (13)有以下程序 #include<stdio.h> main() {int n[2],i,j; for(i=0;i<2;i++)n[i]=0; for(i=0;i<2;i++) for(j=0;j<2;j++)n[j]=n「i」+1; printf(”%d\\n”,n[1]); } 程序运行后的输出结果是【13】 解答:3 二级C语言2010年培训 (14)以下程序的功能是:借助指针变量找出数组元素中最大值所在的位置并输出该最大值。请在输出语句中填写代表最大值的输出项。 #include<stdio.h> main() {int a〔10],*p,*s; for(p=a;p-a<10;p++)scanf(”%d”,p); for(p=a,s=a;p-a<10;p++)if(*p>*s)S=P; printf(\n”,【14】); } 解答:*s,题中条件if(*p>*s)s=p;看出指针指向较大的那个元素 (15)以下程序打开新文件f.txt,并调用字符输出函数将a数组中的字符写入其中,请填空。 #include<stdio.h> main() {【15】*fp; char a[5]={’1’,’2’,’3’,’4’,’5’},i; fp=fopen(”f .txt”,”w”); for(i=0;i<5;i++)fputc(a[i],fp); fclose(fp); } 解答:FILE 定义文件指针格式:file *fp; 附II) 上机操作题