全国计算机等级考试二级C语言模拟试题3
www.nanhushi.com 佚名 不详
答案
答案
答案
11.以下叙述中正确的是 A)构成C程序的基本单位是函数 B)可以在一个函数中定义另一个函数 C)main()函数必须放在其他函数之前 D)C函数定义的格式是K&R格式
A B C D
12.一个C语言程序是由 A)一个主程序和若干子程序组成 B)函数组成 C)若干过程组成 D)若干子程序组成
A B C D
13.请选出可用作C语言用户标识符的是 A)void,define,WORD B)a3_b3,_123,IF C)FOR,--abc,Case D)2a,Do,Sizeof
A B C D
14.以下不正确的叙述是 A)在C程序中,逗号运算符的优先级最低 B)在C程序中,APH和aph是两个不同的变量 C)若a和b类型相同,在计算了赋值表达式a=b后,b中的值将放入a中,而b中的值不变 D)当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值
A B C D
15.下面程序的功能是把316表示为两个加数的和,使两个加数分别能被13和11整除,在划线处应填入的选项是 #include main() { int i=0,j,k; do{ i++;k=316-13*i;}while(); j=k/11; printf("316=13*%d+11*%d",i,j); } A)k/11 B)k C)k/11==0 D)k==0
A B C D
答案
16.下面程序的运行结果是 #include main() { int y=10; do{y--;}while(--y); printf("%d\n",y--); } A)-1 B)1 C)8 D)0
A B C D
17.下面程序的输出结果是 main() { int a[10]={1,2,3,4,5,6,7,8,9,10},*p=a; printf("%d\n",*(p+2)); } A)3 B)4 C)1 D)2
A B C D
18.有如下程序 int a[10]={1,2,3,4,5,6,7,8,9,10}; int *p=&a[3],b;b=p[5]; 则b的值是 A)5 B)6 C)9 D)8
A B C D
19.下列程序的输出结果是 main() { double d=3.2; int x,y; x=1.2; y=(x+3.8)/5.0; printf("%d\n", d*y); } A)3 B)3.2 C)0 D)3.07
A B C D
20.下列程序的输出结果是 int b=2; int func(int *a) { b += *a; return(b);} main() { int a=2, res=2; res += func(&a); printf("%d\n",res); } A)4 B)6 C)8 D)10
A B C D
答案
21.执行以下程序后,a,b的值分别为 main() { int a,b,k=4,m=6,*p1=&k,*p2=&m; a=p1==&m; b=(*p1)/(*p2)+7; printf("a=%d\n",a); printf("b=%d\n",b); } A)-1,5 B)1,6 C)0,7 D)4,10
A B C D
22.若已定义 int a[]={0,1,2,3,4,5,6,7,8,9}, *p=a,i; 其中 0≤i≤9, 则对a数组元素不正确的引用是 A)a[p-a] B)*(&a[i]) C)p[i] D)a[10]
A B C D
23.以下不正确的定义语句是 A)double x[5]={2.0,4.0,6.0,8.0,10.0}; B)int y[5]={0,1,3,5,7,9}; C)char c1[]={′1′,′2′,′3′,′4′,′5′}; D)char c2[]={′\x10′,′\xa′,′\x8′};
A B C D
24.若有以下程序 #include int a[]={2,4,6,8}; main() { int i; int *p=a; for(i=0;i<4;i++)a[i]=*p; printf("%d\n",a[2]); } 上面程序输出结果是 A)6 B)8 C)4 D)2
A B C D
25.下面程序段的运行结果是 char *format="%s,a=%d,b=%d\n"; int a=11,b=10; a+=b; printf(format,"a+=b",a,b); A)for,"a+=b",ab B)format,"a+=b" C)a+=b,a=21,b=10 D)以上结果都不对
A B C D
答案
26.以下程序有语法错误,有关错误原因的正确说法是 main() { int G=5,k; void prt_char(); ... k=prt_char(G); ... } A)语句 void prt_char();有错,它是函数调用语句,不能用void说明 B)变量名不能使用大写字母 C)函数说明和函数调用语句之间有矛盾 D)函数名不能使用下划线
A B C D
27.以下叙述中不正确的是 A)在不同的函数中可以使用相同的名字的变量 B)函数中的形式参数是局部变量 C)在一个函数内定义的变量只在本函数范围内有效 D)在一个函数内的复合语句中定义的变量在本函数范围内有效
A B C D
28.有以下程序: #include union pw { int i; char ch[2];}a; main() {a.ch[0]=13;a.ch[1]=0;printf("%d\n",a.i);} 程序的输出结果是 A)13 B)14 C)208 D)209
A B C D
29.在16位IBM-PC机上使用C语言,若有如下定义 struct data { int i; char ch; double f; } b; 则结构变量b占用内存的字节数是 A)1 B)2 C)7 D)11
A B C D
30.下面程序的运行结果是 #include main() { int a=1,b=10; do { b-=a;a++;}while(b--<0); printf("a=%d,b=%d\n",a,b); } A)a=3,b=11 B)a=2,b=8 C)a=1,b=-1 D)a=4,b=9
A B C D
答案
31.以下程序的输出结果是 void reverse(int a[],int n) { int i,t; for(i=0;i{ t=a[i]; a[i]=a[n-1-i];a[n-1-i]=t;} } main() { int b[10]={1,2,3,4,5,6,7,8,9,10}; int i,s=0; reverse(b,8); for(i=6;i<10;i++)s+=b[i]; printf(" %d\n ",s); } A)22 B)10 C)34 D)30
A B C D
32.有如下程序 long fib(int n) { if(n>2)return(fib(n-1)+fib(n-2)); else return(2); } main() { printf("%d\n",fib(3));} 该程序的输出结果是 A)2 B)4 C)6 D)8
A B C D
33.假定以下程序经编译和连接后生成可执行文件PROG.EXE,如果在此可执行文件所在目录的DOS提示符下键入PROG ABCDEFGH IJKL<回车>,则输出结果为 main( int argc, char *argv[]) { while(--argc>0) printf("%s",argv[argc]); printf("\n"); } A)ABCDEFG B)IJHL C)ABCDEFGHIJKL D)IJKLABCDEFGH
A B C D
34.函数 rewind 的作用是 A)使文件位置指针重新返回文件的开始位置 B)将文件位置指针指向文件中所要求的特定位置 C)使文件位置指针指向文件的末尾 D)使文件位置指针自动移至下一个字符位置
A B C D
35.阅读以下程序及对程序功能的描述,其中正确的描述是 #include main() { FILE *in,*out; char ch,infile[10],outfile[10]; printf("Enter the infile name:\n"); scanf("%s",infile); printf("Enter the outfile name:\n"); scanf("%s",outfile); if((in=fopen(infile,"r"))==NULL) { printf("cannot open infile\n"); exit(0); } if((out=fopen(outfile,"w"))==NULL) { printf("cannot open outfile\n"); exit(0); } while(! feof(in))fputc(fgetc(in),out); fclose(in); fclose(out); } A)程序完成将磁盘文件的信息在屏幕上显示的功能 B)程序完成将两个磁盘文件合二为一的功能 C)程序完成将一个磁盘文件复制到另一个磁盘文件中 D)程序完成将两个磁盘文件合并并在屏幕上输出
A B C D
答案
答案
6.以下程序将数组a的4个元素和数组b的6个元素写到名为lett.dat的二进制文件中,请填空。 #include main () { FILE *fp; char a[4]="1234",b[6]="abcedf"; if((fp=fopen(" 【6】 ","wb"))=NULL)exit(0); fwrite(a,sizeof(char),4,fp); fwrite(b, 【7】 ,1,fp); fclose(fp); }
输入答案,中间不含空格:
7.在C语言中(以16位PC机为例),一个float型数据在内存中所占的字节数为4;一个double型数据在内存中所占的字节数为 【8】 。
输入答案,中间不含空格:
8.以下程序输出的结果是 【9】 。 main() { int a=5,b=4,c=3,d; d=(a>b>c); printf("%d\n",d); }
输入答案,中间不含空格:
9.以下函数的功能是求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。 例如,若x中的值为30,则有4个数符合要求,它们是1,3,5,15。 请按题意,完成填空。 试题程序: #include #include void fun (int x, int pp[], int *n) { int i,j=0; 【10】 if(x%i==0)pp[j++]=i; 【11】; } main () { int x,aa[1000], n, i ; clrscr(); printf("\nPlease enter an integer number : \n "); scanf ("%d ", &x); fun (x, aa, &n); for (i=0 ; i printf ("%d ", aa [i]); printf ("\n "); }
输入答案,中间不含空格:
10.以下函数用来求出数组的最大元素在数组中的下标并存放在k所指的存储单元中。请填空。 #include #include int fun(int *s, int t, int *k) { int i; *k=0; 【12】 if(s[*k] return【13】; } main() { int a[10]={ 876,675,896,101,301,401,980,431,451,777},k; clrscr(); fun(a, 10, &k); printf("%d, %d\n ", k, a[k]); }
输入答案,中间不含空格:
答案
11.以下函数用来求出数组的最大元素在数组中的下标并存放在k所指的存储单元中。请填空。 #include #include int fun(int *s, int t, int *k) { int i; *k=0; 【12】 if(s[*k] return【13】; } main() { int a[10]={ 876,675,896,101,301,401,980,431,451,777},k; clrscr(); fun(a, 10, &k); printf("%d, %d\n ", k, a[k]); }
输入答案,中间不含空格:
12.设有以下结构体类型: struct st { char name[8]; int num; float s[4]; } student[50]; 并且结构体数组student中的元素都已有值,若要将这些元素写到硬盘文件fp中,请将以下fwrite语句补充完整: fwrite(student,【15】,1,fp);
输入答案,中间不含空格:
文章录入:杜斌 责任编辑:杜斌
上一篇文章: 全国计算机等级考试二级C语言模拟试题4答案 下一篇文章: 全国计算机等级考试二级C语言模拟试题2
【字体:小 大 】【发表评论 】【加入收藏 】【告诉好友 】【打印此文 】【关闭窗口 】
联 系 信 息
QQ:88236621 电话:15853773350 E-Mail:malenurse@163.com 免费发布招聘信息 做中国最专业男护士门户网站
最 新 热 门
最 新 推 荐
相 关 文 章
没有相关文章