C语言考试试卷_第1页
C语言考试试卷_第2页
C语言考试试卷_第3页
C语言考试试卷_第4页
C语言考试试卷_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、二级 C语言考试试卷(考试说明及第一部分计算机基础知识略)第二部分 C语言程序设计一、选择题(用答题卡答题,答案依次填在2130答题号内)21. 若有声明语句char s110=0,s210= books;则能将字符串books赋给数组s1保存的表达式是 21 。A. s1=”books”; B. strcpy(s2,s1);C. s1=s2; D. strcat(s1,s2);22. 表达式(a=4*5,b=a*2),b-a,a+=2的值是 22 。A2 B. 20 C. 22 D. 42 23. 以下是一个自定义函数的头部,其中正确的是 23 。A. int fun(int a ,b) B

2、. int fun(int a ,int a)C. int fun(int * a,int b) D. int fun(char a ,int b)24. 以下数组声明语句中正确的是 24 。Aint n,an; B. int a ;C. int a23=1,2,3; D. int a 3=1,2,3; 25已知在某C语言编译系统中表达式sizeof(int)的值是2,如果希望将常量-70000正确地保存在一个变量a中,该变量声明语句应当是 25 。Aint a; B. long int a;C. unsigned int a; D. unsigned long int a;26. 以下声明语

3、句中,用于声明一个行指针变量的是 26 。A. int *p(int); B. int *p;Cint (*p)3; D. int (*p)(int);27. 已知A盘根目录下的一个文本数据文件data.dat中存储了100个int型数据,若需要修改该文件中已经存在的若干个数据的值,只能调用依次fopen函数,已有声明语句FILE*fp;则fopen 函数的正确调用形式是 27 。A. fp=fopen(”a:data.dat”,”r+”); B. fp=fopen(”a:data.dat”,”w+”);C. fp=fopen(”a:data.dat”,”a+”); D. fp=fopen(”

4、a:data.dat”,”w”);28. 在以下程序中,需要在fun函数中声明一个int型的变量,以下选项中 28 不能用作该变量的名字。Ax B. y C. fabs D. fun #includeint y;main( )int a=1; fun(a);int fun(int x) ; /* int型变量声明语句位置*/ /*若干执行语句*/29如有语句:int x,y=0,z,* p3;p0=&x;p1=&y;p2=&z; 以下表达式中有语法错误的是 29 。Ay+ B. p+ C. *+p0 D. (*p0)+30. 设有声明语句:int a33=1,2,3,4,5,6,7,8,9;以

5、下语句中除 30 外均能输出a12的值。Aprintf(“%d”,*(*(a+1)+2); B. printf(“%d”,*(&a20-1);C. printf(“%d”,*(a1+2); D. printf(“%d”,*(a+1)2);二、填空题(将答案填写在答题纸的响应答题号内,每个答案只占一行)l 基本概念题(共5分)1只能在循环体中出现的语句是 (1) 语句。2 & 既可以用作单目运算符也可以用作双目运算符,其中用作单目运算符时表示的功能是 (2) 。3包含二目运算符的表达式可一般的表示为(x)op(y),其中op代表运算符x、y代表操作数。若op 是“+”运算符,且x和y均为常量时,

6、不能同时为 (3) 常量。4当 (4) 语句被执行时,程序的执行流程无条件地从一个函数跳转到另一个函数。5在函数内部声明局部变量时缺省了存储类型,该变量存储类型为 (5) 。l 阅读程序写出运行结果题(共10分)6以下程序段运行后,x、y、z的值分别是 (6) 。int x=0,y=3,z=2;if(x+&y+)z-;else if(x+1=6|y-)z+;7. 设有以下宏定义:#define N3#define Y(n) (N+1)* n)则执行语句z=2 * (N+Y(5+1);后,z的值为 (7) 。8程序int x=1;main( ) int y,k; y=f(3);printf(“%

7、dn%d”,x,y);int f(int x) if(x=3) int x=2; return x; else return x; 该程序运行后,输出x 的值是 (8) ,y的值是 (9) 。9程序main() int a33=1,2,3,4,5,6,7,8,9,m,k,t;for(m=0;m3;m+) for(k=0;k=m;k+) if(m+k)%2) t=amk,amk=akm,akm=t;for(m=0;m3;m+) for(k=0;k3;k+) printf(“%d”,amk); printf(“n”);该程序执行时输出第一行是 (10) ,第二行是 (11) 。10程序#inclu

8、deint convert(char s1 ,char s2 ,int *n1) int i=0,j=0,k,s=0,len;int value=0;char tab16=”0123456789ABCDEF”;len = strlen(s1);if(len%4) for(i=0;ilen%4;i+) s=s*2+s1i-0; s2j+=tabs;value=value*16+s;while(ilen) s=0; for=(k=0;k4;k+) s=s*2+s1i+k-0;s2j+=tabs;value=value*16+s;i=r+4;s2j=0;* n1=strlen(s2);return

9、value;main( ) char ss1 =”1001010”,ss210; int x,y;y=convert(ss1,ss2,&x);printf(“%dn%dn%s”,x,y,ss2);该程序执行时输出第一行是 (12) ,第二行是 (13) ,第三行是 (14) 。11程序main( ) int a33,i,j; numlist(&a00,9);for(I=0;I3;I+) for(j=0;j3;j+)printf(“%d”,aij); printf(“n”); numlist(int *p,int n) int i;for(i=0;in;i+) pi=num(i); num(in

10、t n) if(n=0)return 1;return num(n-1)*2+1;程序执行时输出的第一行是 (15) 。l 完善程序题(共15分)12程序功能:合并两个已经按照升序排列的一维数组。Insert函数功能:将m插入x指向的含有n个元素的数组中,数组中n个元素已按升序排列,插入m后的n+1个元素仍保持有序。void insert(int x ,int n,int m);main( ) int a10=1,3,5,7,9,b5=2,4,8,16,32,k;for(k=0;k5;k+) insert(a, (16) ,bk);for(k=0;kxn-1) (17) =m; else fo

11、r (i=; (18) ;i+); for(j=n;j=i;j-) xj= (19) ; xi=m; 13 程序功能:查找满足下列条件的m,n值。给定正整数k,0m=k,0n=k,求使(n2-mn-m2)2=1 且使n2+m2的值达到最大的值。# includemain( ) long m,n,k,s,flag=0;printf(input k:);scanf(%ld,&k);n=k;do m=_(20)_;do s=n*(n-m)-m*m;if(s*s=1) (21) ;else m-; while(m0&! flag);if(m=0) (22) ;while(n0&! flag);prin

12、tf(m=%ld,n=%ld,m,n);14 已知链表中结点的数据结构定义如下:# includestruct node int x;struce node *next;;函数loop功能:根据dir的值循环移位head指向的链表中的所有结点,当dir为正整数时实现循环右移一次,否则循环左移一次。函数返回链表首结点的指针。例如,移位前的链表数据:head-1-3-5-4。右移一次后的链表数据:head-4-1-3-5。算法提示:循环右移时,将链表最后一个结点删除,再将其插入到链表首部;循环左移时,将链表的第一个结点删除,再将其连接到链表尾部。struct node *loop(struce n

13、ode *head,int dir) struct *p1,*p2;p1=head;if(p1=null|p1-next=null) return head;if(dir=0)while(p1-next) p2=p1;p1=p1-next;(23) = null;p1-next= (24) ;head=p1;else head= (25) ;p2=head;while(p2-next)p2=p2-next;(26) ;p1-next=null;return head;15 程序功能:在一行文本中查找给定的单词。一行文本由字母和分隔符组成,分隔符包括若干空格,逗号,句号和换行符。一个单词由若干个

14、连续字母组成。程序说明:main函数中的word数组存放欲查找的单词。find_word函数完成在t字符串中查找s指向的字母字符串的功能,如未找到返回0,找到则返回s串在t串中出现的次数并将所有出现位置的起始下标保存在x指向的数组中。#inclued#include#includeint find_word(char*, char*, int* );main( ) char text80=I will pass the examination in the summer holiday.,word20;int j,t,pos10;puts(enter a word to be found: )

15、;gets(word);t=find_word (text,word, (27) );if( (28) ) printf(Find word %sin text. It locate in,word); for (j=0;jt;j+)printf(text%d,posj);else printf(not find);int find_word(char * t, char* s, int*x) char w20;int i,j,k=0;for(i=0;ti!= 0;i+) if( isalpha(ti) for (j=0; isalpha(ti+j); j+) wj= (29) ;wj= 0;

16、if(strcmp(s,w)=0) x k+=i;i= (30) ;return k;参 考 答 案一、选择题21D 22. C 23. C 24. D 25. B 26. C 27. A 28. A 29. B 30. D二、填空题(1) continue (2)取操作数地址 (3)字符串(4) return (5)auto (6)1,2,3(7) 48 (8)1 (9) 2(10)1 4 3 (11)2 5 8 (12)2(13)74 (14)4A (15)1,3,7(16) k+5 (17)xn (18)xinext (24)head(25)p1-next (26)p2-next = p

17、1 (27)pos(28)t (29)ti+j (30)i+j-1二级 C语言上机试卷(本试卷完成时间70分钟)一、改错题(20分)【题目】以下程序中函数fixed的功能是:将实型数f转换为十进制字符串形式存放到数组c中,当f0时,首字符存放“”,否则存放“+”,小数点后存放有效位数7位,不足的部分用“0”补足,多余部分截尾。例如,程序正确时将输入实型数 1.23456789 转换为字符串“+ 1.2345678”输出。 # include # include # define MAX 100 void fixed(int f, char c) int i,j; double x; char

18、*p= c,*q= c + MAX 1; if(f0) *p+ =-,f= -f; else *p+=+; i = int(f); x=f-i ; *q-= 0 ; while(i!=0) *q= i%10 + 0; i=i/0; strcpy(p, q + 1); p=p + strlen(q + 1); (*p)+ =.; i=1;while(i=7) j=(x =x * 10); *p+=j +0;i+ +; x=x-j; *p=0;main() double y; char sMAX; scanf(%lf, &y)fixed(y,s);puts(s);【要求】1将上述程序录入到文件my

19、fl.c中,根据题目要求及程序中语句之间的逻辑关系对程序中的错误进行修改。2改错时,可以修改语句中的一部分内容,调整语句次序,增加少量的变量说明或编译预处理命令,但不能增加其他语句,也不能删去整条语句。3改正后的源程序(文件名myfl.c)必须放在考盘的根目录上,供阅卷用,否则不予评分。二、编程题(20分)【题目】按以下要求编写程序:1编写函数int countvalue(int aa ),其功能是:求出500到 800区间内的素数及素数的个数cnt,将这些素数按从小到大的顺序依次存入aa指向的数组中,函数返回cnt的值。2编写主函数,调用countvalue函数,将所找到的所有素数保存到文件

20、myf2.out中。【要求】1 源程序文件名必须取为myf2.c,输入结果文件名为myf2.out。2 数据文件的打开、使用、关闭等操作均用C标准库中缓冲文件系统的文件操作函数实现。3 源程序文件和运行结果文件均需保存在考试盘根目录中共阅卷使用。4 不要复制扩展名为obj和exe的文件到考试盘中。参 考 答 案一、改错题(20分)#include#include#define MAX 100void fixed (int f,char c ) /* 正确 double f int i , j ;double x ;char * p=c , *q=c+MXA-1 ; if ( f0 ) * p +=- , f= - f ;else * p+=+ ;i = int ( f ) ; /* 正确 i= (int)f;或i=f;*

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论