1、第七届全国信息技术应用水平大赛模拟题C语言程序设计注:模拟题题量总计88道,其中单选题60道,每道题1分;多选题20道,每道题2分;程序填充题6道,每道题5分;编程操作题2 道,每道题10分。试卷满分为150分,完成时间为180分钟。此模拟题仅供参考,具体题型、题量、分值分配与试题难度以实际预赛题为准。单选题(共60题,每题1分,共60分) 1. 下列符号串中,属于C语言合法标识符的个数为( )。_1_2_3,a-b-c,float,9cd,a3b4 A:1B:2C:3D:42. 下列能为字符变量 a 赋值的是:char a= ( )。A:abB:aC:0D:03. 在下列字符序列中,合法的标
2、识符是( )。A:P12.aB:stud_100C:$water.1D:88sum4. 下列用于printf函数的控制字符常量中,代表tab的字符常量是( )。A:bB:tC:rD:f5. 下列用于printf函数的控制字符常量中,代表退格的字符常量是( )。A:bB:tC:rD:n6. 如有以下程序:unsigned int a=6; int b=-20; char c; c=(a+b6);则c的值为( )。A:6B:-14 C:1D:07. 关于C语言,以下不正确的叙述是( )。A:在C语言程序设计中,逗号运算符的优先级最低B:在C语言程序设计中,var和VAR是两个相同的变量C:C语言也
3、支持重载D:此处的两个语句inta; a=-13.06;在程序编译中将会提示出错8. 若有定义:int a=2,*p;float x=1, y=2; char e=w;则以下用法不正确的是( )。A:printf(%c,e+a);B:p=&x;C:a *=y+x;D:x=y=e;9. int x=20; printf(%dn,x);以上程序片段的输出是( )。A:235B:-21C:-20D:-1110. 在C语言中,要求运算数必须是整型的运算符是( )。 A:/B:+C:!=D:%11. 若有定义:int a=7;float x=2.5,y=4.7;则表达式x+a%3*(int)(x+y)%
4、2/4的值是(结果保留两位小数)( )。A:2.50B:2.75C:3.50D:0.0012. 以下运算符中优先级最低的是( )。A:&B:&C:|D:|13. 设有定义语句:char c1=1,c2=1;,则以下表达式中值为零的是( )。A:c1c2B:c1&c2C:c2D:c1|c214. 以下程序的输出结果是#include void main() unsigned char a,b; a=0x0a|3; b=0x0a&3; printf(%d %dn,a,b); ( )。A:2 11B:11 2C:7 13D:13 715. 如果int i = 4, 则printf(%d, -i- )
5、的输出结果是( ),i的值是( )。A:-4 3B:-3 3C:-3 4D:-4 416. 若x=2,y=3则x&y的结果是( )。A:1B:2C:3D:517. 下列程序的输出是( )。main()int x;printf(%dn,(x=3*5,x*2,x+10);A:15B:25C:30D:4018. 若x,i,j和k都是int型变量,则计算下面表达式后,x的值为( )。x=(i=4,j=16,k=32)A:4B:16C:32D:其他值19. 假设所有变量均为整型,则表达式(a=2,b=5,b+,a+b)的值是( )。A:7B:8C:6D:220. 以下程序运行后的输出结果是( )。mai
6、n()int a,b;a=50;b=90;printf(%dn,(a,b);A:90B:50 90C:50D:其他21. 以下程序的运行结果是( )。void main() int a=4; char ch=a; printf( %dn,(a&2)&(chA);A:0B:1C:2D:322. 以下程序的输出是( )。#include main( ) int i,j=4; for(i=j; i=2*j; i+)switch (i/j) case 0 : case 1: printf(*); break; case 2: printf(#); break;A:*#B:*#C:*#D:*#23. 有
7、如下程序片段:int i = 0;while(i+ = 2); printf(%d, i-);则正确的执行结果是 ( )。A:2B:3C:4D:以上都不是24. 有以下程序段main() int i=1,sum=0,n; scanf(“%d”,&n);do i+=2; sum+=i ;while(i!=n);printf(“%d”,sum);若使程序的输出值为15,则应该从键盘输入的n的值是 ( )。A:1B:3C:5D:725. 以下程序的输出是( )。 #include void fun(int *p) int a=10; p=&a; +a; void main() int a=5; fu
8、n(&a); printf(%dn,a); A:5B:6C:10D:1126. 以下关于函数的说法中正确的是 ( )。A:定义函数时,形参类型说明可放在函数体内B:return语句后边的值不能为表达式C:如果函数类型与返回值类型不一致,以函数类型为准D:如果形参与实参的类型不一致,以实参为准27. 已知有定义:int *p(); 则以下说法正确的是 ( )。A:指向int型的指针变量B:int型的指针数组C:一个函数,该函数的返回值是指向int型的指针变量D:一个指向函数的指针变量,该函数的返回值为int型28. 若有如下程序:void s(char *m,int n) *m=*m+3;n=n
9、+3;printf(%c,%c,*m,n);void main() char p=b,q=B;s(&q,p);printf(%c,%cn,p,q);则程序运行后的输出结果是 ( )。A:E,e,b,EB:e,E,b,FC:E,e,e,ED:e,E,b,E29. C语言规定函数返回值的类型由 ( )。A:在定义时所指定的函数类型所决定B:调用该函数时的主调函数类型所决定C:return语句中的表达式类型所决定D:调用该函数时系统临时决定30. 要在c语言中求正弦30度的值,可以调用库函数,可用格式为 ( )。A:sin(30)B:sin(30.0)C:sin(double)30)D:sin(3.
10、1415/6)31. 在C语言程序设计中,简单变量作为实参时,它和对应形参之间的数据的传递方式是 ( )。A:地址传递B:单向值传递C:由实参传给形参,再由形参传给实参D:由用户指定传递方式32. 以下程序的输出为( )。int a=2;int f(int *a) return(*a)+;void main() int s=0; int a=5; s+=f(&a); s+=f(&a); printf(%d %dn,a,s);A:2 7B:2 10C:3 7D:3 1133. 以下程序输出结果是( )。#include int *fun()int a4,k;for(k=0;k4;k+)ak=k;
11、return(a);void main() int *p,j;p=NULL;p=fun();for(j=0;j4;j+)printf(%dn,*p);p+;A:输出0 0 0 0 B:输出0 1 2 3C:输出1 1 1 1D:输出不确定值34. 以下程序的运行结果是( )。void fun(int *n) static int m=2; *n*=m-1; m+=2;void main() static int m=1; int i; for(i=1;i4;i+) fun(&m); printf(%dn,m);A:8B:10C:11D:1535. 下面对typedef的叙述中不正确的是 ( )
12、。A:用typedef可以定义各种类型名,但不能用来定义变量B:typedef和#define都是在预编译时处理的C:用typedef只是将已存在的类型用一个新的标识符来代表D:使用typedef有利于程序的通用和移植36. 要使用内存分配函数malloc,需要引入的头文件是 ( )。A:stdio.hB:stdlib.hC:malloc.hD:memory.h37. 以下宏定义中,不会引起二义性的宏个数为( )。1)#define POWER(x) x*x2) #define POWER(x) (x)*(x)3) #define POWER(x) (x*x)4) #define POWER(
13、x) (x)*(x)A:1个B:2个C:3个D:4个38. 若有二维数组定义语句:int a45; 则下面对元素a23不正确的引用方式是( )。A:*(&a23)B:*(a+5*2+3)C:*(a2+3)D:*(*(a+2)+3)39. 若二维数组定义为amn,则在aij之前的元素个数为 ( )。A:j*m+iB:i*m+jC:i*m+j-1D:j*m+i-140. 有字符数组a10=A,0和b10=B,则以下正确的输出语句是 ( )。A:puts(a,b);B:printf(%s %sn,a,b);C:putchar(a,b);D:puts(a);puts(b);41. 下列程序的输出结果是
14、( )。#include #include void main() char p120=abcd,p220=ABCD; char str50=xyz; strcpy(str+2,strcat(p1+2,p2+1); printf(%sn,str);A:xyabcABB:abcABzC:AbabczD:xycdBCD42. 以下程序执行后输出结果是( )。void main() char a=movie,b10=movie; printf(%d %dn,sizeof(a),sizeof(b);A:5 5B:6 6C:6 10 D:10 1043. 以下程序的输出结果是( )。void main(
15、) char *p10=abc,aabdfg,dcdbe,abbd,cd;printf(%dn,strlen(p4);A:2B:3C:4D:编译出错44. 已知有以下的说明, int a=8,1,2,5,0,4,7,6,3,9; 那么a*(a+a3)的值为 ( )。A:5B:0C:4D:745. 以下程序输出结果是( )。#include main() int a22=1,2,3,4,(*p)2; p=a; p+; printf(%dn,*p ); A:2B:3C:4 D:以上都不对46. 设char ch,str4,*strp;,则正确的赋值语句是 ( )。A:ch=CBA;B:str=CB
16、A;C:strp=CBA;D:*strp=CBA;47. 下面程序的运行结果是( )。#include #include fun(char *w,int n)char t,*s1,*s2;s1=w;s2=w+n-1;while(s1s2)t=*s1+;*s1=*s2-;*s2=t;main()char *p;p=1234567;fun(p,strlen(p);puts(p);A:7654321B:1714171C:1711717D:717717148. 以下程序的输出是( )。#include main()char a=language,*p;p=a;while(*p!=u) printf(%
17、c,*p-u+U);p+;A:LANGUAGEB:languageC:LANGD:LANGuage49. struct s1 char a3; int num;t=a,b,x,4,*p;p=&t;则输出为x的语句是( )。 A:printf(“%cn”,p-t.a2); B:printf(“%cn”,(*p).a2) C:printf(“%cn”,p-a3); D:printf(“%cn”,(*p).t.a2);50. 以下程序的输出是( )。#include main() struct st int x; int y; cnum2=1,3,2,7; printf(%dn,cnum0.y/cn
18、um0.x*cnum1.x);A:0B:1C:3D:651. 以下对age的非法引用是( )。struct student int age; int num; stu1,*p;p=&stu1;A:stu1.ageB:student.ageC:p-ageD:(*p).age52. 以下程序的输出是( )。#include union myunstructint x,y,z;u;int k;a;void main()a.u.x=4;a.u.y=5;a.u.z=6;a.k=0;printf(%dn,a.u.y);A:4B:5C:6D:053. 若要用fopen函数打开一个二进制文件,该文件要既能读也
19、能写,当文件不存在时新建文件,则文件打开方式字符串应是( )。A:ab+B:rb+C:wb+D:ab54. 若执行fopen函数时发生错误,则函数的返回值是 ( )。A:地址值B:0C:1D:EOF55. 要打开文件c:usertext.txt用于追加数据,正确的语句是( )。A:fp=fopen(c:turboc2abc.txt,r);B:fp=fopen(c:turboc2abc.txt,r);C:fp=fopen(c:turboc2abc.txt,a+);D:fp=fopen(c:turboc2abc.txt,a+);56. 在执行fopen函数时,ferror函数的初值是 ( )。A:
20、TRUEB:-1C:1D:057. #include main() char * s1=Hello,*s2=Beijing; FILE *pf=fopen(abc.dat,wb+); fwrite(s2,7,1,pf); fseek(pf,-1,SEEK_CUR); fwrite(s1,5,1,pf); fclose(pf); 以上程序执行后,文件abc.dat中的内容为 ( )。 A:HellongB:Beijing HelloC:BeijinHelloD:Hello58. 若fp为文件指针,且文件已正确打开,i为整型数据,以下语句的输出结果是( )。fseek(fp,0,SEEK_END)
21、;i=ftell(fp);printf(i=%dn,i);A:fp所指的文件记录长度B:fp所指的文件长度,以字节为单位C:fp所指的文件长度,以比特为单位D:fp所指的文件当前位置,以字节为单位59. 函数调用语句:fseek(fp,-20L,2);的含义是 ( )。A:将文件位置指针移到距离文件头20个字节处B:将文件位置指针从当前位置向后移动20个字节C:将文件位置指针从文件末尾处后退20个字节 D:将文件位置指针移到离当前位置20个字节处60. 若将文件指针的读写位置指针移动到距离文件头200个字节的位置,对应正确的操作是 ( )。A:fseek ( fp, 200, SEEK_SET
22、 )B:fseek ( fp, 200, SEEK_CUR )C:fseek ( fp, 200, SEEK_END )D:ftell ( 200 )多选题(共20题,每题2分,共40分) 1. 关于以下运算,说法正确的有 ( )。A:设有宏定义#define F(N) 2*N,则表达式F(2+3)的值是10B:设int x=4;则执行语句x += x *= x + 1;后,x的值为40C:设int a, b = 8;执行a = b2 + 1;后a的值是33D:设int a34, *p = a1; 该指针变量p指向的元素是a102. 有以下定义:char a10,*b=a;则能给a数组输入字符
23、串的语句有 ( )。A:gets(a);B:gets(a0);C:gets(&a0);D:gets(b);3. 要求函数的功能是在一维数组a中查找x值。若找到,则返回所在的下标值;否则,返回0。设数据放在数组元素的a1到an中。在以下给出的函数中,不能正确执行此功能的函数有 ( )。A:funa(int *a, int n, int x) *a = x; while(an != x) n-; return n;B:funb(int *a, int n, int x) int k; for(k = 1; k = n; k+) if(ak = x) return k; return 0;C:fun
24、c(int a, int n, int x) int *k; a0 = x; k = a+n; while(*k != x) k-; return k - n;D:fund(int a, int n, int x) int k = 0; do k+; while(k n+1)&(ak!=x); if(k n+1)&ak = x) return k; else return 0;4. 关于下列程序的输入与输出,正确的说法有( )。#include void main() int m,n; printf(Enter m,n); scanf(%d%d,&m,&n); while(m!=n) whil
25、e(mn)m-=n; while(nm)n-=m; printf(m=%dn,m);A:输入mn时,程序将输出1B:输入mn时,程序输出值为n的值D:输入m或n为0时,程序将陷入死循环5. 已知有如下程序:void main() int a5=1,2,3,4,5,*b; b=(int*)malloc(sizeof(int); _; printf(%dn,*b);要使程序输出为a2的值,则函数fun的定义和横线处对应的fun调用的正确有 ( )。A:void fun(int*s,int*d)*d=*(s+2);调用: fun(a,&b)B:void fun(int*s,int&d)d=*(s+2
26、);调用: fun(a,b)C:void fun(int*s,int &d)d=*(s+2);调用: fun(a,*b)D:void fun(int*s,int *d)*d=*(s+2);调用: fun(a,&b)6. 以下函数欲实现交换x和y的值,且通过正确调用返回交换结果。不能实现这一功能的有 ( )。A:funa(int *x, int *y) int *p; *p = *x; *x = *y; *y = *p;B:funb(int x, int y) int t; t = x; x = y; y = t;C:func(int *x, int *y) int p; p = *x; *x
27、= *y; *y = p;D:fund(int *x, int *y) int *p; *x = *x + *y; *y = *x - *y; *x = *x - *y;7. 函数调用时,下列说法中正确的有 ( )。A:若用值传递方式,则形式参数不予分配内存B:实际参数和形式参数可以同名C:主调函数和被调用函数可以不在同一个文件中D:函数间传递数据可以使用全局变量8. 下面叙述正确的有( )。A:函数调用可以出现在表达式中B:函数调用可以作为一个函数的实参C:函数调用可以作为一个函数的形参D:函数可以直接调用其本身9. 下列说法中正确的有 ( )。A:递归函数的形参是自动变量B:有些递归函数是
28、不能用非递归算法来实现的C:c语言不允许这样的函数调用:函数A调用了函数B,而函数B又调用了函数AD:C语言不允许函数的嵌套定义10. 下列关于指针与引用的说法,正确的有 ( )。A:引用只能在定义时被初始化一次,以后不能改变B:指针可以被重新赋值以指向另一个不同的对象C:引用和指针都可以指向空值D:引用和指针都可以用const修饰11. 若有如下定义:int s3;则下面表达式中,表示数组元素s1的有 ( )。A:*&s1B:*(&s0+1)C:*(s+1)D:*(&(s0+1)12. 已知:int a=1,*p=&a;则以下表达式可以得到a的值的有 ( )。A:*pB:p0C:*&a D:
29、*&p13. 若有定义:char *str=one,two,three,*p=str; 则可以表示出字符t的表达是 ( )。A:*str2B:*str+2C:*(p+1)D:*+p14. 若有以下定义和语句,则对w数组元素的正确引用有int w23, (*pw)3; pw=w; ( )。A:*(w0+2)B:pw00C:*pw2D:*(pw1+2)15. 设有以下语句struct st int n; struct st *next; ;static struct st a3=5,&a1,6,&a2,7,NULL,*p=&a0;则以下表达式的值为6的有 ( )。A:p-n+B:+p-nC:(+p
30、)-nD:p-next-n16. 以下关于结构类型变量的定义正确的有 ( )。A:struct data int num; float price; &book;B:struct data int num; float price; book;book b;C:struct data int num; float price; book;struct data &d=book;D:typedef struct data int num; float price; book;book b;17. 以下scanf函数调用语句中对结构体变量成员的正确引用有()。struct pupil char n
31、ame 20 ; int age; int sex; pup 5 ,*p;p=pup;A:scanf(%s,pup 0 .name);B:scanf(%d,&pup 0 .age);C:scanf(%d,&(psex);D:scanf(%d,page);18. 以下关于枚举类型的用法中,正确的有 ( )。A:enum a 1,2,3;B:enum a a,b,c;C:enum a a,b,cd;D:enum a a,b,ca;19. 设有如下说明,则正确的说法有()。union data int i; char c; float f;a;A:a所占的内存长度等于成员f的长度B:a的地址和它的各
32、成员地址都是同一地址C:a可以作为函数参数D:不能直接对a赋值20. 设有结构类型:typedef struct str int no; char name20;STR;另有变量定义:STR a20, x;以下语句希望实现,向与文件指针变量fp关联的文件输出一个结构信息,正确的代码有( )。A:fwrite(a, sizeof(STR), 1, fp);B:fwrite(&a2, sizeof(STR), 1, fp);C:fwrite(&x, sizeof(STR), 1, fp);D:fwrite(x, sizeof(STR), 1, fp);程序填充题(共6题,每题5分,共30分) 1.
33、 下面程序的功能是统计用0至9之间的不同的数字组成的三位数的个数。main() int i,j,k,count=0;for(i=1;i=9;i+)for(j=0;j=9;j+)if( ) continue;else for(k=0;k=9;k+)if( ) count+;printf(%d,count);2. 下面程序的功能是将字符串s中的每个字符按升序的规则插到数组a中, 字符串a已排好序。#include main() char a20=cehiknqtw;char s=fbla;int i,k,j;for(k=0;sk!= 0;k+ ) j=0;while(sk=aj & aj!= 0
34、)j+;for( ) ;aj=sk;puts(a);3. 下面程序的功能是用辗转相除法求两个正整数m和n的最大公约数。hcf(int m,int n) int r;if(mamax) amax=x; if( ) amin=x;scanf(%f,&x);printf(namax=%fnamin=%fn,amax,amin);5. 下面程序的功能是不用第三个变量,实现两个数的对调操作。#include main() int a,b;scanf(%d%d,&a,&b);printf(a=%d,b=%dn,a,b);a= ; b= ; a= ;printf(a=%d,b=%dn,a,b);6. 下面程序的功能是根据近似公式:2/6 1/12+1/22+1/32+ +1/n2,求值。#include double pi(long n) double s=0.0;long i;for(i=1;i=n;i+)s=s+ ;return( );编程操作题(共2题,每题10分,共20分) 1. 将1到9这九个数字分成3个三位数a,b,c,要求第1个三位数,正好是第2个三位数的两倍,是第3个三