《C语言试题及答案教学文稿.doc》由会员分享,可在线阅读,更多相关《C语言试题及答案教学文稿.doc(43页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Good is good, but better carries it.精益求精,善益求善。C语言试题及答案-一、问答题1、局部变量能否和全局变量重名?答:能,局部会屏蔽全局。要用全局变量,需要使用:局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。2、如何引用一个已经定义过的全局变量?答:extern可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理
2、,假定你将那个变写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?答:可以,在不同的C文件中以static形式来声明同名全局变量。可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错4、语句for(;1;)有什么问题?它是什么意思?答:和while(1)相同。5、dowhile和whiledo有什么区别?答:前一个循环一遍再判断,后一个判断以后再循环6、请写出下列代码的输出内容#includemain()i
3、nta,b,c,d;a=10;b=a+;c=+a;d=10*a+;printf(b,c,d:%d,%d,%d,b,c,d);return0;答:10,12,1207、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?全局变量(外部变量)的说明之前再冠以static就构成了静态的全局变量。全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。这两者在存储方式上并无不同。这两者的区别虽在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。而静态全局
4、变量则限制了其作用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。从以上分析可以看出,把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的作用域,限制了它的使用范围。static函数与普通函数作用域不同。仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数的源文件要包含这个头文件s
5、tatic全局变量与普通的全局变量有什么区别:static全局变量只初使化一次,防止在其他文件单元中被引用;static局部变量和普通局部变量有什么区别:static局部变量只被初始化一次,下一次依据上一次结果值;static函数与普通函数有什么区别:static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝8、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区)中,动态申请数据存在于(堆)中。9、设有以下说明和定义:typedefunionlongi;intk5;charc;DATE;structdataintcat;DATEcow;doubledog;too;DATEmax;
6、则语句printf(%d,sizeof(structdate)+sizeof(max);的执行结果是:_52_答:DATE是一个union,变量公用空间.里面最大的变量类型是int5,占用20个字节.所以它的大小是20data是一个struct,每个变量分开占用空间.依次为int4+DATE20+double8=32.所以结果是20+32=52.当然.在某些16位编辑器下,int可能是2字节,那么结果是int2+DATE10+double8=2010、队列和栈有什么区别?队列先进先出,栈后进先出11、写出下列代码的输出内容#includeintinc(inta)return(+a);intmu
7、lti(int*a,int*b,int*c)return(*c=*a*b);typedefint(FUNC1)(intin);typedefint(FUNC2)(int*,int*,int*);voidshow(FUNC2fun,intarg1,int*arg2)INCp=&inc;inttemp=p(arg1);fun(&temp,&arg1,arg2);printf(%dn,*arg2);main()inta;show(multi,10,&a);return0;答:110二、C语言部分一、选择题(每小题2分,共10分)1、若定义:inta230,2,4,6,8,10;以下描述正确的有(A,
8、C,D,E)A、*(a+1)为元素6的地址这里a+1=a1的地址;*(a+1)的值是6,故A正确。B、*(a1+1)的值为2为8,故B不正确C、*(a+1)+2的值为8这里a+1是一个指针,指向的是a1.*(a+1)为a1,a1指向的是a10.*(a+1)为6,加2得8,故C正确;D、a0与a相同因二者都是指针,指针的地址都是指向数组中的第一个元素的地址,故D正确。E、a12的值为10它是指第二行的第三个元素,为10,正确2、对函数的正确使用方法描述(A,C,D)。A、用数组做函数参数时,必须在主调函数和被调函数中分别定义数组B、实参数组元素和形参数组元素类型可以不一致C、形参数组长度可以不指
9、定D、形参数组长度可以大于实参数组长度E、数组名做参数属于值传递3、对静态变量的正确描述(A,B,D,E)A、静态局部变量在静态存储区内分配单元()B、静态外部变量可以赋初值,也可以不赋初值C、静态外部变量的作用与外部变量相同D、静态局部变量在函数调用结束时,仍保存其值,不会随着消失。E、静态局部变量只赋一次初值4、下列描述正确的是(A,C)。A、由main函数及其参数argc和*argv可以实现命令行方式B、使用fclose关闭文件时,先释放文件指针,再写缓冲区数据到文件中/先写缓冲区数据到文件中,再释放文件指针C、字符数组并不要求它的最后一个字符是0/是的,以字符指针指向的字符串才要求,因
10、为只有这样,才能知道字符串的长度,而在字符数组中,不用0,一样可以知道到哪里是字符数组的结尾。D、A和“A”都是字符串常量E、若char*S=“ta017bc”;则指针变量S指向的字符串所占的字节数是75、在缓冲文件系统中用于读写的函数有(A,B,D)A、putchar()B、fread()C、rewind()D、purw()E、fseek()二、程序阅读,并给出运行结果(1)main()unsigneda,b,xintn;a=0x763输出结果:n=6;b=a(12-n);x=(an-2)b;/+,-,的优先级比高。printf(“nb=%x,nx=%x”,b,x);在用2个字节表示整数的系
11、统中结果为d8c0d8b6在用4个字节表示整数的系统中结果为1d8c01d8b6故以上两种结果都正确。(2)#includestdin.hstructmintx;int*y;*p;inta4=12,33,-40,100;structmb4=10,&a2,9,&a3,8,&a0,7,&a1main()p=b;输出结果:printf(“%dn”,+p-x);/-的优先级高于+,因此等于是+(p-x),为11printf(“%dn”,(+p)-x);/p后移一个元素,其x值为9;printf(“%dn”,+(*p-y));/-的优先级高于*,此时p已指向b1,故*(p-y)为a3为100.自加后为1
12、01;故输出结果为:119101三、程序设计设在文件a.txt和文件b.txt中分别存有两个字符串,设计一个程序将这两个字符串按依序交叉的方式合并为一个字符串(例如“aaaaa”与“bbb”的合并结果为“abababaa”,而“bbb”与“aaaaa”的合作结果为“bababaa”,)并将结果存入文件a.txt中。【答案】写程序时,可以分别读取a.txt文件和b.txt文件,注意(1),无论a文件先读完还是b文件先读完,程序都能作出适应性的判断。注意(2)把a和b合并的结果,写到一个临时文件c中,最后把c的文件覆盖到a文件中,达到题意的要求。#includemain()FILE*fp,*fq,
13、*fr;charch;if(fp=fopen(a.txt,r+)=NULL)printf(cannotopenfilea.txt);exit(0);if(fq=fopen(b.txt,r)=NULL)printf(cannotopenfileb.txt);exit(0);fr=fopen(c.txt,w+);while(!feof(fp)ch=fgetc(fp);fputc(ch,fr);if(!feof(fq)ch=fgetc(fq);fputc(ch,fr);while(!feof(fq)ch=fgetc(fq);fputc(ch,fr);rewind(fp);rewind(fr);whi
14、le(!feof(fr)ch=fgetc(fr);fputc(ch,fp);fclose(fp);fclose(fq);fclose(fr);一、单项选择题1、t表示什么?A字符串常数B标识符C变量D字符常量(D)注:后面选择题答案均为D2、对宏定义不正确的描述是哪一个?A在进行宏定义时,可以引用已经定义的宏名,可以层层置换/可以引用已经定义了的宏名,可以层层置换B宏名的有效范围包括本文件的任何位置/宏名的有效范围定义命令之后到本源文件结束,可以用#define终止宏定义的作用域C宠定义不是语句,不必在行末加分号/是预处理定义语句D对程序中双引号括起来的字符串,即使与宏名相同,也不进行置换3、
15、若定义staticchars20=”computer”;则执行语句x=strlen(s);之后,x的值为多少?209819/strlen函数计算char*型字符串的长度的时候,并不包含末尾的0;4、以下哪一个表达式取值是正确的?65结果为665结果为76|5结果为765结果为05、如定义enumweekdayone,two,thr,fou,fiv;enumweekdayworking;以下哪个是不正确的枚举变量的使用?working=thr;working=2;working=(enumweekday)2;working=(enumweekday)(5-3);/不能对其赋值6、下列说法中正确的
16、是哪一个?sizeof(char)是结果为整型的表达式sizeof(char)是一个不合法的表示形式sizeof(char)是一种函数调用sizeof(char)是结果为实型的表达式二、阅读程序,并回答问题1、下列程序的输出是什么?#includevoidmain()char*aplha6=“ABC”,“DEF”,“GHI”,“JKL”,“MNO”,“PQR”;char*p;inti;p=aplha;for(i=0;i4;i+)printf(“%s”,pi);printf(“n”);/输出结果ABCDEFGHIJKL刚好是字符串数组里面的前四个元素的内容连接起来2、下列程序为什么无法将用户输入
17、的三个整数按从小到大排序输出?应该如何修改?(6分)#includevoidswap(intx,inty)intt=x;x=y;y=t;voidmain()inta,b,c;scanf(“%d,%d,%d”,a,b,c);if(ab)swap(a,b);if(ac)swap(a,c);if(bc)swap(b,c);printf(“%d,%d,%d”,a,b,c);/函数swap采用值传递,虽然将形参x和y交换了,但是并不影响到实参。将值传递改成指针传递就可以了。C函数参数采用值传递方式,虽然swap函数将形式参数x和y的值进行了调换,但是影响不到相应的实在参数。所以在主函数中,通过调用saw
18、p函数调换a和b(或a或c,或b和c)的值是根本达不到目的的。修改:(1)(2分)voidswap(int*x,int*y)intt=*x;*x=*y;*y=t;(2)(2分)主函数if(ab)swap(a,b);if(ac)swap(a,c);if(bc)swap(b,c);3、假设系统为基本整型量分配2个字节,为字符型量分配1个字节。下列程序完成的功能是什么?(3分)#includeunionintn;charch2;u;voidmain()intm;scanf(“%d”,m);u.n=m;printf(“n%u,%u”,u.ch0,u.ch1);/该程序的功能,取用户输入的整数值的高字节
19、和低字节,并按照任意整数的低字节和高字节分别输出。三、程序设计题假设一个文本文件中保存着100个整数,请将这100个整数按从小到大的顺序写到另一个文本文件中去,并且在新文件中每10个整数占一行。源文件名和目标文件名通过命令行参数获取。分数分配:变量定义2分命令行参数处理1分文件打开1分文件读2分排序3分文件写2分文件关闭1分#includevoidmain(intargc,char*argv)FILE*fin,*fout;Inta100,i,j,t;if(argc!=3)printf(“Youforgottoenterafilenamen”);return;fin=fopen(argv1,“r
20、”);fout=fopen(argv2,“w”);for(i=0;i100;i+)fscanf(fin,“%d”,ai);for(i=0;i99;i+)for(i=0;iaj+1)t=aj;aj=aj+1;aj+1=t;for(i=0;i100;i+)if(i%10=0)fprintf(fout,“%s”,“n”);fprintf(fout,“%d”,ai);fclose(fin);fclose(fout);二、阅读程序,写出该程序的执行结果。#includestdio.hvoidmain()chara310=Beijing,Shanghai,Chengdu;charp1,(*p2)10;p1
21、=a0;p2=a;printf(%cn,*(a1+1);/a1代表是第一行字符串Shanghai,加1后得值第一个字符h的地址,*取出其地址里的值hprintf(%cn,*(*(a+1)+2);/*(a+i)=ai代表是第一行字符串Shanghai,加2后得值第2个字符a的地址,*取出其地址里的值printf(%cn,*(p1+1);/p1是一字符指针,加一指向第零行第1个字符e的位置,*取出其地址里的值printf(%cn,*(*(p2+1)+2);/p2为一指向数组的指针,p2是与数组名等价的指针,它指向2维数组的首行,p21指针指向了第一行字串Shanghai,加2后得值第2个字符a的地
22、址,*取出其地址里的值printf(%sn,*(p1+1);/打印的从第一个字符开始的第零行余下的字符串eijingprintf(%sn,*(p22);/p22指的是第二行,打印第二行字符串Chengduprintf(%sn,*(p21);/p2+1指向的是第一行字符串shanghai三、按要求编写函数。在一程序中定义了如下结构类型用于处理单向链表:structlinkageintvalue;structlinkage*pNext;现已经编写出按节点的成员a值从小到大建立初始链表的函数create(),如下所示:structlinkage*create(void)structlinkage*p
23、Head;inta4=2,1,3,5;pHead=NULL;for(i=0;i4;i+)pHead=addItem(pHead,ai);returnpHead;在该函数的for循环前,pHead为NULL;在执行整个for循环后,创建的链表如下所示:即在被调函数addItem()中,需要动态分配内存,生成新节点,将传入的第二参数的值赋给该节点的成员value:并通过第一个参数链表首节点确定适当位置放置该新节点。请完成函数:structlinkage*addItem(structlinkage*pHead,intvalue);返回值指向单向链表头节点。你可能用到下面的动态内存分配函数。void*
24、malloc(unsignedintsize);其作用是在内存的动态存储区中分配一个长度为size的连续空间。返回值为指向分配域起始地址的指针。1、在空链表中加第一个节点2分;2、加到当前链表头节点前2分;3、加到当前链表头节之后适当位置,可分为两步。2分;4、其它部分2分,包括整体结构,变量定义,返回值。structlinkage*addItem(structlinkgae*pHead,intvalue)structlinkage*p,*q,*r,*s;p=pHead;if(!p)r=(structlinkage*)malloc(sizeof(structlinkage);r-a=value
25、;r-pNext=NULL;pHead=r;elseif(value=p-a)r=(structlinkage*)malloc(sizeof(structlinkage);r-a=value;r-pNext=p;pHead=r;elseq=ppNext;while(q)if(value=q-a)break;elsep=q;q=p-pNext;r=(structlinkage*)malloc(sizeof(structlinkage);r-a=value;r-pNext=q;p-pNext=r;returnpHead;四、程序设计。单位HTML文件由标签,标题和正文主体等部分组成。如下所示:HT
26、MLHEADTITLEHTML标题部分/HEAD这里是HTML文件的主体部分。换新行。/HTML符号及其之间的内容是标签,如HTML,等。其它部分是标题和主体。请按以下说明和要求完成程序,将简单的HTML文件转换为TXT文件:1序将简单HTML文件的有标签和换行符(n)(去掉。标题部分结束(遇到标签)后加上一个换行符(n)。每一个标签换成一个换行符(n)。其余部分原样保留。如上面的简单HTML文件处理为(表示换行):HTML标题部分这里是HTML文件的主体部分。换新行。2简单HTML文件的标签内没有嵌套情况,即在这间不会再出现。3标签内的内容大小写无关。如,等价。4示签的与标签内容间无空格。即
27、不会出现或等情况。5标题和正文中不会出现字符,它们通过转义字符实现,这时尤需考虑。6程序需要处理命令行参数。第一个参数指要处理的HTML文件名,第二个参数指定处理后要存放的文件名。这两个文件都是文本文件。7程序必须进行必要的出错处理,如无法打开文件等。8程序不需要包含头文件。1、main()函数形参处理:2分。2、变量定义1分。3、打开关闭文件2分;4、读源文件1分;5、能从标签中找出内容BR/TITLE换为n部分2分;6、区分开标签和其它部分,并按要求写入目标文件2分;7、整体结构正确2分;voidmain(intargc,char*argv)charC,tag7;intstatus,len
28、;FILE*fin,*fout;if(argc!=3)printf(参数个数不对!)exit(1)if(fin=fopen(argv1,r)=NULL)printf(“打不开源文件”);exit(1);if(fout=fopen(argv2,w)=NULL)printf(无法写入文件!);fclose(fin);exit(1);status=0;while(c=fgetc(fin)!=EOF)switch(C)case:status=1;len=0;break;case:status=0;if(len=6)taglen=0;if(!strcmp(tag,”/title”)|!strcmp(ta
29、g,”br”)fputc(n,fout);break;casen:break;default:if(!status)fputc(c,fout);elselen+;if(len=6);taglen-1=c;fclose(fin);fclose(fout);C语言程序设计)一、分析下面的程序,写出程序执行结果。(每小题4分,共2分)1、#includestdio.hvoidswap(int*p1,int*p2)int*t;t=*p1;p1=p2;*p2=t;voidmain()inta=1、b=3、*p=&a、*q=&b;swap(&p、&q);printf(%d、5d、%d、%dn、a、b、*p
30、、*q;/因为在swap函数里交换的是两个参数的地址,所以参数使用的是两级指针,表示交换的是指针的地址,最终使p指向了b,q指向了a。1,3,3,12.#includevoidmerge(char*d、charsl、char、S2)while(*sl!=0&*S2!=0)if(*sl*s2)d+=*sl+;elsed+=*s2+;while(*sl!=0)*d+=sl+;while(*s2!=0)*d+=s2+;*d=0,voidmain()charsl=acdgh,s2=bcfhi,s320;merge(s3,s1,s2);puts(s3)/将两个字符串合为一个按照字母顺序排列的串abccd
31、fghhi二、按要求完成C函数。(每小题10分,共20分)1intmaxsameChar(char*s);该函数计算字符串s中最大连续相同的字符个数。例如,若s为aaabbbb,则返回值为4;若s为abcde,则返回值为1。intmaxSameChar(char*s)inttemp=1,max=0;charc=0;while(*s)if(c=*s)tmpe+;elsec=*s;temp=1;if(maxtemp)max=temp;s+;returnmax;2structmode*reverse(structmode*pHead);其中,structnode定义如下:structnodeintk
32、ey;structnode*pNext;此函数传入的pHead指向要处理的单向链表头,该链表以NULL指针结束。函数实现链表链接方向(包括pHead指向的原头节点)的反转,如图1所示。并将新链表头指针作为函数值返回。在完成此函数时,你只能利用原有链表节点,不能申请新节点空间。structnode*reverse(structnode*pHead)structnodt*p,*q,*t;if(pHead=NULL)returnNULL;p=pHead;q=p-pNext;while(q!-NULL)t=q-pNext;q-pNext=p;p=q;q=t;pHead-pNext=NULL;pHead=p;returnpHead;-