c语言程序设计课程模拟试卷及答案(2秋季).doc
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 课程 模拟 试卷 答案 秋季
- 资源描述:
-
一、单选题(每小题2分,共20分) 1、 C语言源程序文件得缺省扩展名为( c )。 2.设x与y均为逻辑值,则x && y为真得条件就是x与y( 均为真 )。 3、 在下列得符号常量定义中,正确得定义格式为( #define M3 10 )。 4、 for循环语句能够被改写为( while )语句。 5、 在下面得一维数组定义中,错误得定义格式为( int a[]; )。 6.在下面得函数原型声明中,存在语法错误得就是(int AA(int a; int b;); )。 7、 假定a为一个数组名,则下面存在错误得表达式为( *a++ )。 8、 假定有定义为“int a[10], x, *pa=a;”,若要把数组a中下标为3得元素值赋给x,则不正确得赋值为( x=*pa+3 )。 9.字符串"y=%d\n"得长度为__5__。 10、 向一个二进制文件中写入信息得函数为(fwrite() )。 二、填空题(每小题2分,共26分) 1.执行“printf("%c",'A'+3);”语句后得到得输出结果为_D_ 2.短整数类型short int得长度为 2 3、 用类型关键字表示十进制常数3、26f得类型为_float 4、 假定y=10,则表达式++y*3得值为_33 5、 逻辑表达式(x==0 && y>5)得相反表达式为_(x!=0 || y<=5) 或:(x || y<=5) 6.若x=5,y=10,则x!=y得逻辑值为_1(真,true) 7、 假定二维数组得定义为“int a[3][5];”,则该数组所占存储空间得字节数为_60 8、 使用“typedef char BB[10][50];”语句定义_BB为含有10行50列得二维字符数组类型。 9、 字符串"a:\\xxk\\ff"得长度为9 10.假定p所指对象得值为25,p+1所指对象得值为46,则*++p得值为_46 11、 假定一个数据对象为int*类型,则指向该对象得指针类型为_int** 12.假定一个结构类型得定义为 “struct A{int a,b; struct A* c;};”,则该类型得理论长度为__12 13、 假定要访问一个结构对象x中得数据成员a,则表示方式为_x、a 三、写出下列每个程序运行后得输出结果(每小题6分,共30分) 1、 #include<stdio、h> void main() { int x=3; switch(2*x+1) { case 4: printf("%d ",x); break; case 7: printf("%d ",2*x); break; case 10: printf("%d ",3*x); break; default: printf("%s ","default"); } }输出结果:6 2、 #include<stdio、h> void main() { int f=1,i; for(i=1;i<4;i++) f=3*f+1; printf("%d ",f); }输出结果:40 3、 #include<stdio、h> void main() { int a[8]={12,39,26,41,55,63,72,40}; int i, c=0; for(i=0; i<8; i++) if(a[i]%3==0) c++; printf("%d\n",c); }输出结果:4 4、 #include<stdio、h> #include<string、h> void main( ) { char s[]="123456"; int i, n=strlen(s) ; for(i=0; i<n/2; i++) { char c=s[i]; s[i]=s[n-1-i]; s[n-1-i]=c; } printf("%s\n",s); }输出结果:654321 5、 #include<stdio、h> int LB(int *a, int n) { int *p,s=1; for(p=a; p<a+n; p++) s*=*p; return s; } void main() { int a[]={1,2,3,4}; printf("%d\n", LB(a,sizeof(a)/sizeof(int))); // sizeof(a)为求出数组a所占用得存储空间得字节数} 输出结果:24 四、写出下列每个函数得功能(每小题6分,共12分) 1、 #include<stdio、h> int SA(int a, int b) { if(a>b) return 1; else if(a==b) return 0; else return -1; } 函数功能:比较两个整数a与b得大小,若a>b则返回1,若a==b则返回0,若a<b则返回-1。 2、 void Output(struct IntNode *f) //f为单链表得表头指针 { if(!f) return; while(f) { printf("%d ",f->data); f=f->next; } printf("\n"); } 函数功能:遍历输出由f所指向得单链表中每个结点得值。 五、按题目要求编写程序(每小题6分,共12分) 1、 完善下面程序,该程序功能就是从键盘上输入10个整数到一维数组a[10]中,然后按照下标从大到小得次序输出数组a[10]中得每个元素值,元素值之间用一个空格分开。 #include<stdio、h> void main() { int a[10],i; //用i作为循环变量 printf("从键盘输入10个整数: \n"); //向下补充程序内容,用两个for循环实现 printf("\n"); } for(i=0; i<10; i++) scanf("%d",&a[i]); //3分 for(i=9; i>=0; i--) printf("%d ",a[i]); //6分 注:第1行中得&a[i]也可替换为a+i 2、 编写一个主函数,假定a与b得取值范围为:6≤a≤50,10≤b≤30,求出满足不定方程3a+2b=120得全部整数组解。如(20,30)就就是其中得一组解。 void main() { int a,b; //1分 for(a=6;a<=50; a++) //2分 for(b=10;b<=30;b++) //3分 if(3*a+2*b==120) printf("(%d, %d)\n",a,b); //6分 一、单选题 1.在每个C语言程序中都必须包含有这样一个函数,该函数得函数名为( main )。 2.每个C语言程序文件得编译错误分为( 2 )类。 3、 字符串"a+b=12\n"得长度为( 7 )。 4、 在switch语句得每个case块中,假定都就是以break语句结束得,则此switch语句容易被改写为( if )语句。 5、 在下面得do-while循环语句中,其循环体语句被执行得次数为( 10 )。 int i=0; do i++; while(i<10); 6、 将两个字符串连接起来组成一个字符串时,选用得函数为( strcat() )。 7、 若用数组名作为函数调用得实参,传递给形参得就是( 数组得首地址 )。 8、 假定a为一个整数类型得数组名,整数类型得长度为4,则元素a[4]得地址比a数组得首地址大( 16 )个字节。 9、 假定s被定义为指针类型char *得变量,初始指向得字符串为"Hello world!",若要使变量p指向s所指向得字符串,则p应定义为( char *p=s; )。 10、 从一个数据文件中读入以换行符结束得一行字符串得函数为( fgets() )。 11、 由C语言目标文件连接而成得可执行文件得缺省扩展名为( exe )。 12、 设有两条语句为“int a=12; a+=a*a;”,则执行结束后,a得值为( 156 )。 13、 带有随机函数调用得表达式rand()%20得值在( 0~19 )区间内。 14、 for循环语句“for(i=0; i<n; i+=2) S;”中循环体S语句被执行得次数为( (n+1)/2 )。 15、 在下列得字符数组定义中,存在语法错误得就是( char a[10]='5'; )。 16、 B 17、 B 18、 A 19、 D 20、 C 21、 D 22、 A 23、 A 24、 B 25、 C 26、 C 27、 C 28、 B 29、 A 30、 D 16、 若有一个函数原型为“double *function()”,则它得返回值类型为( 实数指针型 )。 17、 在C语言中,所有预处理命令都就是以( # )符号开头得。 18、 假定整数指针p所指数据单元得值为30,p+1所指数据单元得值为40,则执行*p++后,p所指数据单元得值为( 40 )。 19、 若要使p指向二维整型数组a[10][20],则p得类型为( int(*)[20] )。 20、 表示文件结束符得符号常量为( EOF ) 21、 程序运行中需要从键盘上输入多于一个数据时,各数据之间默认使用( 空格或回车 )符号作为分隔符。 22、 逻辑表达式(x>0 && x<=10)得相反表达式为( x<=0 || x>10 )。 23、 当处理特定问题时得循环次数已知时,通常采用( for )循环来解决。 24、 假定i得初值为0,则在循环语句“while(i<n) {s+=i*i; i++;}”中循环体被执行得总次数为( n )。 25、 假定一个二维数组得定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]得值为( 6 )。 26、 在下列选项中,不正确得函数原型格式为( int Function(a); )。 27、 假定p就是一个指向float型数据得指针,则p+1所指数据得地址比p所指数据得地址大( 4 )个字节。 28、 假定有定义为“int m=7, *p;”,则给p赋值得正确表达式为( p=&m )。 29假定指针变量p定义为“int *p=malloc(sizeof(int));”,要释放p所指向得动态存储空间,应调用得函数为( free(p) )。 30、 C语言中得系统函数fopen()就是( 打开 )一个数据文件得函数。 1.C语言中得每条简单语句以__;(或分号)_作为结束符。 2、 C程序中得所有预处理命令均以_#_字符开头。 3、 当不需要函数返回任何值时,则应使用_void_标识符来定义函数类型。 4.十进制数25表示成符合C语言规则得十六进制数为_0x19。 5假定不允许使用逻辑非操作符,则逻辑表达式a>b || b==5得相反表达式为__a<=b && b!=5 6、 执行“typedef int DataType;”语句后,在使用int定义整型变量得地方也可以使用__DataType来定义整型变量。 7、 假定一维数组得定义为“char* a[8];”,则该数组所占存储空间得字节数为__32_。 8、 假定二维数组得定义为“double a[M][N];”,则该数组得列下标得取值范围在__0~N-1_之间。 9、 存储一个空字符串需要占用_1 _个字节。 10、 strcpy函数用于把一个字符串_拷贝(复制)_到另一个字符数组空间中。 11、 程序得编译单位就是一个_程序文件__。 12、 假定a就是一个一维数组,则a[i]得指针访问方式为__*(a+i)_。 13、 执行int *p=malloc(sizeof(int))操作得到得一个动态分配得整型对象为_*p _。 14.执行“printf("%c",'A'+2);”语句后得到得输出结果为__ C_。 15.short int类型得长度为__2。 16、 用类型关键字表示十进制常数3、26f得类型为__float。 17、 假定y=10,则表达式++y*3得值为__33 。 18、 逻辑表达式(x==0 && y>5)得相反表达式为__(x!=0 || y<=5) 或:(x || y<=5) 。 19.若x=5,y=10,则x!=y得逻辑值为__1 20、 假定二维数组得定义为“int a[3][5];”,则该数组所占存储空间得字节数为__60。 21、 使用“typedef char BB[10][50];”语句定义__BB_为含有10行50列得二维字符数组类型。 22、 字符串"a:\\xxk\\数据"得长度为__11 23.假定p所指对象得值为25,p+1所指对象得值为46,则*++p得值为__46 。 24、 假定一个数据对象为int*类型,则指向该对象得指针类型为__int** 。 25.假定一个结构类型得定义为 “struct A{int a,b; A* c;};”,则该类型得长度为_12 26、 假定要访问一个结构对象x中得数据成员a,则表示方式为__x、a。 27、 用于输出表达式值得标准输出函数得函数名就是__printf。 28.每个C语言程序文件在编译时可能出现有致命性错误,其对应得标识符为__error 29、 已知'A'~'Z'得ASCII码为65~90,当执行“int x='C'+3;”语句后x得值为_70。 30、 表达式(int)14、6得值为__14。 31、 假定不允许使用逻辑非操作符,则关系表达式x+y>5得相反表达式为_x+y<=5 32、 假定x=5,则执行“a=(x?10:20);”语句后a得值为___10。 33、 假定一维数组得定义为“char* a[M];”,则该数组所占存储空间得字节数为___4*M。 34、 存储字符串"a"需要至少占用存储器得_2_个字节。 35、 strlen()函数用于计算一个字符串得_长度 36、 在C语言中,一个函数由函数头与___函数体_这两个部分组成。 37.假定p所指对象得值为25,p+1所指对象得值为46,则执行表达式*(p++)后,p所指对象得值为_ 46。 38、 假定p就是一个指向整数对象得指针,则用__ &p_表示指针变量p得地址。 39、 与结构成员访问表达式p->name等价得访问表达式为_(*p)、name。 三、写出下列每个程序运行后得输出结果 1、 #include<stdio、h> void main() { int x=5; switch(2*x-1) { case 4: printf("%d ",x); break; case 7: printf("%d ",2*x); break; case 10: printf("%d ",3*x); break; default: printf("%s ","default"); } printf("%s\n","switch end、"); } 输出结果default switch end、 2、 #include<stdio、h> void main() { int f1,f2,i; f1=1; printf("%d ",f1); for(i=2;i<=5;i++) { f2=3*f1+1; printf("%d ",f2); f1=f2; } printf("\n"); } 输出结果1 4 13 40 121 3、 #include<stdio、h> void main() { int a[10]={12,39,26,41,55,63,72,40,83,95}; int i, i1=0, i2=0; for(i=0;i<10;i++) if(a[i]%2==1) i1++; else i2++; printf("%d %d\n",i1,i2); } 输出结果6 4 4、 #include<stdio、h> #include<string、h> void main( ) { char s[15]="567891234"; int i, n=strlen(s) ; for(i=0; i<n/2; i++) { char c=s[i]; s[i]=s[n-1-i]; s[n-1-i]=c; } printf("%s\n",s); } 输出结果432198765 5、 #include<stdio、h> int LB(int *a, int n) { int i,s=1; for(i=0;i<n;i++) s*=*a++; return s; } void main() { int a[]={1,2,3,4,2,4,5,2}; int b=LB(a,4)+LB(a+3,3); printf("b=%d\n",b); } 输出结果b=56 6、 #include<stdio、h> void main() { int i,s=0; for(i=1;i<6;i++) s+=i*i; printf(“s=%d\n”,s); } 输出结果s=55 7、 #include<stdio、h> #define N 6 void main() { int i,a[N]={2,5,8,10,15,21}; for(i=0; i<N; i++) if(a[i]%5) printf("%d ",a[i]); printf("\n"); } 输出结果2 8 21 8、 #include<stdio、h> #include<string、h> void main() { int i; unsigned int len; char* a[5]={"student","worker","cadre","soldier","zzeasan123"}; len=strlen(a[0]); for(i=1; i<5; i++) if(strlen(a[i])>len) len=strlen(a[i]); printf("%d\n",len); } 输出结果10 9、 #include<stdio、h> void main() { int a,b; for(a=2,b=3; b<20;) { printf("%d %d ",a,b); a=a+b; b=a+b; } printf("%d %d\n",a,b); } 输出结果 2 3 5 8 13 21 10、 #include<stdio、h> void LE(int* a, int* b) { int x=*a; *a=*b; *b=x; } void main() { int x=15, y=26; printf("%d %d\n",x,y); LE(&x,&y); printf("%d %d\n",x,y); } 输出结果15 26 26 15 11、 #include<stdio、h> void main() { int i, s=0; for(i=1;;i++) { if(s>30) break; if(i%2==0) s+=i; } printf("s=%d\n",s); } 输出结果s=42 12、 #include<stdio、h> void main() { int a[9]={36,25,48,24,55,40,18,66,20}; int i, b1, b2; b1=b2=a[0]; for(i=1; i<9; i++) { if(a[i]>b1) b1=a[i]; if(a[i]<b2) b2=a[i]; } printf("%d %d\n",b1,b2); } 输出结果66 18 13、 #include<stdio、h> void SB(char ch) { switch(ch) { case 'A': case 'a': printf("WW "); break; case 'B': case 'b': printf("GG "); break; default: printf("BB "); break; } } void main() { char a1='a',a2='B',a3='f'; SB(a1);SB(a2);SB(a3); printf("\n"); } 输出结果WW GG BB 14、 #include<stdio、h> #define M 6 void main() { int i,x; int a[M]={10,15,22,37,46,58}; for(i=0; i<M/2; i++) {x=a[i]; a[i]=a[M-1-i]; a[M-1-i]=x;} for(i=0; i<6; i++) printf("%d ",a[i]); printf("\n"); } 输出结果58 46 37 22 15 10 15、 #include<stdio、h> struct Worker { char name[15]; int age; float pay; }; void main() { struct Worker x={"wanghua",52,2350}; struct Worker y, *p; y=x; p=&x; printf("%d %7、2f\n", y、age+p->age, p->pay+20); } 输出结果104 2370、00 16、 #include<stdio、h> void main() { int i,j,k=0; for(i=0; i<5; i++) for(j=i; j<5; j++) k++;; printf("%d\n",k); } 输出结果 15 17、 #include<stdio、h> void main() { int x=60; int i=2, p=1; while(1) { if(x%i==0) {p*=i; x/=i;} if(i<x) i++; else break; } printf("%d\n",p); } 输出结果30 18、 #include<stdio、h> void main() { int a[8]={76,63,54,62,40,75,90,58}; int i; for(i=0; i<8; i++) if(a[i]>70) printf("%d ",a[i]); printf("\n"); } 输出结果 76 75 90 19、 #include<stdio、h> void WF(int x, int y) { x=x+y; y+=x; printf("%d %d\n",x,y); } void main() { int x=3, y=8; WF(x,y); } 输出结果11 19 20、 #include<stdio、h> int LA(int *a, int n) { int i,s=0; for(i=0;i<n;i++) s+=a[i]; return s; } void main() { int a[5]={3,4,6,10,20}; int b=LA(a,5); int c=LA(a+2,3); printf("%d %d\n",b,c); } 输出结果 43 36 四、写出下列每个函数得功能 1、 #include<math、h> int SG(int x) { //x为大于等于2得整数 int a=(int)sqrt(x); //sqrt(x)取x得平方根 int i=2; while(i<=a) { if(x%i==0) break; i++; } if(i<=a)return 0; else return 1; } 判断x就是否为一个素数,若就是则返回1,否则返回0。 2、 int FindMax(struct IntNode *f) //f为一个单链表得表头指针 { int x; if(!f) {printf("单链表为空\n"),exit(1);} x=f->data; f=f->next; while(f) { if(f->data>x) x=f->data; f=f->next; } return x; } 假定struct IntNode得类型定义为: struct IntNode { int data; struct IntNode* next;}; 求出由f所指向得单链表中所有结点得最大值。 3、 #include<stdio、h> int SA(int a, int b) { if(a>b) return 1; else if(a==b) return 0; else return -1; } 比较两个整数a与b得大小,若a>b则返回1,若a==b则返回0,若a<b则返回-1。 4、 void Output(struct IntNode *f) //f为单链表得表头指针 { if(!f) return; while(f) { printf("%d ",f->data); f=f->next; } printf("\n"); } 假定struct IntNode得类型定义为: struct IntNode { int data; struct IntNode* next;}; 遍历并输出由f所指向得单链表中每个结点得值。 5、 int SC(int a, int b, int c) { if(a>=b && a>=c) return a; if(b>=a && b>=c) return b; return c; } 求出a,b,c三个数中得最大值并返回。 6、 int* LI(int n) { int* a=malloc(n*sizeof(int)); int i; for(i=0;i<n;i++) scanf("%d",a+i); return a; }首先建立一个动态整型数组a[n],接着从键盘上输入n个整数到a[n]中,最后返回数组a[n]得首地址。 7、 int WC(int a[], int n, int k) { int i, c=0展开阅读全文
咨信网温馨提示:1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。




c语言程序设计课程模拟试卷及答案(2秋季).doc



实名认证













自信AI助手
















微信客服
客服QQ
发送邮件
意见反馈



链接地址:https://www.zixin.com.cn/doc/1362645.html