全国计算机等级考试二级C语言机试题库_第1页
全国计算机等级考试二级C语言机试题库_第2页
全国计算机等级考试二级C语言机试题库_第3页
全国计算机等级考试二级C语言机试题库_第4页
已阅读5页,还剩124页未读 继续免费阅读

下载本文档

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

文档简介

第01套:给定程序中,函数fun的功能是:将形参n所指变量中,各位上为偶数的数去除,剩余的数按原来从高位到低位的顺序组成一个新的数,并通过形参指针n传回所指变量。例如,输入一个数:27638496,新的数:为739。请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>voidfun(unsignedlong*n){unsignedlongx=0,i;intt;i=l;while(*n){t=*n%_1_;if(t%2!=_2_){x=x+t*i;i=i*10;}n=*n/10;)*n=_3_;}main(){unsignedlongn=-l;while(n>99999999lln<0){printf(nPleaseinput(0<n<100000000):*');scanf(”%ld”,&n);}fun(&n);printf("\nTheresultis:%ld\nM,n);}解题思路:第一处:t是通过取模的方式来得到*n的个位数字,所以应填:10。第二处:判断是否是奇数,所以应填:0。第三处:最后通形参n来返回新数x,所以应填:X。给定程序MODI1.C中函数fun的功能是:计算n!。例如,给n输入5,则输出120.000000。请改正程序郸J错误,使程序能输出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>doublefun(intn){doubleresult=1.0;ifn==0return1.0;while(n>l&&n<170)result*=n-returnresult;}main(){intn;printf(HInputN:n);scanf(H%dn,&n);printf(''\n\n%d!=%lf\n\n\n,fun(n));}解题思路:第•处:条件语句书写格式错误,应改为:if(n=O)。第二处:语句后缺少分号。请编写一个函数fun,它的功能是:将一个数字字符串转换为一个整数(不得调用C语言提供的将字符串转换为整数的函数)。例如,若输入字符串"-1234”,则函数把它转换为整数值-1234o函数fun中给出的语句仅供参考。注意:部分源程序存在文件PROG1.C文件中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#include<string.h>longfun(char*p)|}main()/*主函数*/{chars[6];longn;printf(nEnterastring:\nH);gets(s);n=fun(s);printf(H%ld\nn,n);NONO();}NONO(){/*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。*/FILE*fp,*wf;inti;chars[20J;longn;fp=fopen("c:\\test\\in.datM,HrH);wf=fopen(',c:\\test\\out.dat,',HwH);for(i=0;i<10;i++){fscanf(fp,M%su,s);n=fun(s);fprintf(wf,"%ld\n",n);)fclose(fp);fclose(wf);)解题思路:本题是将一个数字字符串转换为•个整数。参考答案:/*以下代码仅供参考*/longfun(char*p){inti,len,t;/*len为串长,t为正负标识*/longx=0;len=strlen(p);if(p[O]='-'){t=-l;len-;p++;}elset=l;/*以卜完成数字字符串转换为一个数字*/while(*p)x=x*10-48+(*p++);returnx*t;注意:由于NONO()这个函数是改卷人用的,叮考生没有什么关系,故下面从第2套试题开始均省略NONO()※※※※※※※※※※※※※※※※※※※※※※※第02套:给定程序中,函数fun的功能是将形参给定的字符串、整数、浮点数写到文本文件中,再用字符方式从此文本文件中逐个读入并显示在终端屏幕上。请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>voidfun(char*s,inta,doublef){/**********found**********/-1—fp;charch;fp=fopen(,,filel.txt,\Hwn);fprintf(fp,"%s%d%f\n",s,a,f);fclose(fp);fp=fopen(nfilel.txtn,"rn);printf(n\nTheresult:\n\nM);ch=fgetc(fp);/**********found**********/while(!feof(_2_)){/**********nd**********/putchar(_3_);ch=fgetc(fp);}putcharC^n');fclose(fp);)main(){chara[10]="Hello!n;intb=12345;doublec=98.76;fun(a,b,c);)解题思路:本题是考察先把给定的数据写入到文本文件中,再从该文件读出并显示在屏幕上。第一处:定义文本文件类型变量,所以应填:FILE*。第二处:判断文件是否结束,所以应填:fp。第三处:显示读出的字符,所以应填:ch。给定程序MODI1.C中函数fun的功能是:依次取出字符串中所有数字字符,形成新的字符串,并取代原字符串。请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>voidfun(char*s){inti,j;for(i=0,j=0;s[iJ!='\O';i++)if(s[i]>='O'&&s[i]<=,9,)/**********found**********/s|j]=s[i];/**********f^)und**********/s[j]="\O";)main(){charitem[80];printf(u\nEnterastring:H);gets(item);printf("\n\nThestringis:\"%s\“\n”,item);fun(item);printf("\n\nThestringofchangingis:\',%s\M\nM,item);)解题思路:第•处:要求是取出原字符串中所有数字字符组成一个新的字符申,程序中是使用变量j来控制新字符串的位置,所以应改为:s[j++]=s[i];。第二处:置新字符串的结束符,所以应改为:sU]=、O';.请编写函数fun,函数的功能是:将M行N列的二维数组中的字符数据,按列的顺序依次放到一个字符串中。例如,二维数组中的数据为:{b[n]=s[j][i];WWWWn=i*M+j+1;SSSS)HHHH)则字符串中的内容应是:WSHWSHWSHobfn^AO';注意:部分源程序在文件PROG1.C中。)请勿改动主函数main和其它函数中的任何内容,※※※※※※※※※※※※※※※※※※※※※※※仅在函数fun的花括号中填入你编写的若干语句。第03套:给定源程序:程序通过定义学生结构体变量,存储了学生的学号、#include<stdio.h>姓名和3门课的成绩。所有学生数据均以二进制方式输#defineM3出到文件中。函数fun的功能是用写形参filename所指#defineN4文件中最后一个学生的数据,即用新的学生数据覆盖该voidfun(chars[][N],char*b)学生原来的数据,其它学生的数据不变。{inti,j,n=O;请在程序的下划线处填入正确的内容并把下划线删for(i=0;i<N;i++)/*请填写相应语句完成其功能除,使程序得出正确的结果。号注意:源程序存放在考生文件夹下的BLANK1.C(中。不得增行或删行,也不得更改程序的结构!)给定源程序:b[n]='\0';#include<stdio.h>)#defineN5main()typedefstructstudent{char{longsno;charnameflO];HVHVH'});floatscore[3];inti,j;}STU;printf(HThematrix:\nH);voidfun(char"filename,STUn)for(i=0;i<M;i++){FILE*fp;{ for(j=0;j<N;j++)/********* d**********/printf("%3c",w[i][j]);fp=fopen(_l_,"rb+");printf("\n");/**********found**********/)fseek(_2_,-lL*sizeof(STU),SEEK_END);fun(w,a);/**********found**********/printf("TheAstring:\n");puts(a);fwrite(&n,sizeof(STU),1,_3_);printf(M\n\nM);fclose(fp);NONO();})main(){STUt[N]={{10001JMaChao”,91,92,77),解题思路:{10002;,CaoKai,\75,60,88},{10003,“LiSi”,85,70,本题是把二维数组中的字符数据按列存放到•个字符78},{10004,MFangFangH,90,82,87},{10005,"ZhangSan'1,串中。95,80,88});1.计算存放到一维数组中的位置。STUn={10006/'ZhaoSiH,55,70,68},ss[N];2.取出二维数组中的字符存放到一维数组(已计算出intij;FILE*fp;的位置)中。fp=fopenC'student.dat*',uwb");参考答案:fwrite(t,sizeof(STU),N,fp);voidfun(chars[][N],char*b)fclose(fp);(fp=fopenC^tudent.daf,nrbu);inti,j,n=O;fread(ss,sizeof(STU),N,fp);for(i=0;ivN;i++)/*请填写相应语句完成其功能*/fclose(fp);{for(j=0;j<M;j++)printf(H\nTheoriginaldata:\n\nn);for(j=0;j<N;j++){printf(n\nNo:%ldName:%-8sScores:n,ss|j].sno,ss[j].name);for(i=0;i<3;i++)printf(M%6.2fM,ss[j].score[i]);printf(M\nM);}funC^student.dat",n);printf(H\nThedataaftermodifing:\n\nM);fp=fopen(nstudent.datM,Mrbn);fread(ss,sizeof(STU),N,fp);fclose(fp);for(j=0;j<N;j++){printf(n\nNo:%ldName:%-8sScores:H,ss|j].sno,ss[j].name);for(i=0;i<3;i++)printf(M%6.2fss[j].score[i]);printf(,,\nn);)解题思路:本题是考察如何从文件中读出数据,再把结构中的数据写入文件中。第一处:从指定的文件中读出数据,所以应填:filenameo第二处:读取文件fp的最后一条记录,所以应填:fPo第三处:再把读出的记录,写入文件fp指定的位置匕所以应填:fPo给定程序MODI1.C中的函数Creatlink的功能是创建带头结点的单向链表,并为各结点数据域赋0到m-1的值。请改正函数Creatlink中指定部位的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#include<stdlib.h>typedefstructaa{intdata;structaa*next;}NODE;NODE*Creatlink(intn,intm){NODE*h=NULL,*p,*s;inti;/********************/p=(NODE)malloc(sizeof(NODE));h=p;p->next=NULL;for(i=l;i<=n;i++){s=(NODE*)malloc(sizeof(NODE));s->data=rand()%m;s->next=p->next;p->next=s;p=p->next;}/**********found***********/returnp;}outlink(NODE*h){NODE*p;p=h->next;printf(H\n\nTHELIST:\n\nHEAD”);while(p){printf(n->%dn,p->data);p=p->next;}printf("\n");)main(){NODE*head;head=Creatiink(8,22);outlink(head);)解题思路:第一处:指向刚分配的结构指针,所以应改为:p=(N0DE*)malloc(sizeof(NODE));第二处:在动态分配内存的下一行语句是,使用临时结构指针变量h保存p指针的初始位置,最后返回不能使用p.是因为p的位置已经发生了变化,所以应改为返回ho请编写函数fun,函数的功能是:统计一行字符串中单词的个数,作为函数值返回。一行字符串在主函数中输入,规定所有单词由小写字母组成,单词之间由若干个空格隔开,一行的开始没有空格。注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#include<string.h>#defineN80intfun(char*s){)main(){charline[NJ;intnum=0;printf("Enterastring:\nH);gets(line);num=fun(line);printf(HThenumberofwordis:%d\n\nn,num);NONO();)解题思路:本题是统计字符串中的单词数。.利用while循环语句和指针变量,当字符为空格时、则单词数k加1。.循环结束返回ko参考答案:intfun(char*s){intk=1;while(*s){if(*s=")k++;s++;)returnk;}※※※※※※※※※※※※※※※※※※※※※※第04套:程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数fun的功能是从形参filename所指的文件中读入学生数据,并按照学号从小到大排序后,再用二进制方式把排序后的学生数据输出到filename所指的文件中,覆盖原来的文件内容。请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#defineN5typedefstructstudent{longsno;charname[10];floatscore[3];}STU;voidfun(char*filename){FILE*fp;intij;STUs[N],t;/**********found**********/fp=fopen(filename,_1_);fread(s,sizeof(STU),N,fp);fclose(fp);for(i=0;i<N-l;i++)for(j=i+l;j<N;j++)/**********found**********/if(s[i].sno_2_s[j].sno){t=s[i];s[i]=s[j];s[j]=t;}fp=fopen(filename,Mwbu);/**********found**********/_3_(s,sizeof(STU),N,fp);/*二进制输出*/fclose(fp);)main(){STUt[N]={{10005,"ZhangSan",95,80,88},{10003;'LiSiM,85,70,78},{10002,MCaoKaiH,75,60,88},{10004;'FangFang\90,82,87},{10001;,MaChaoM,91,92,77}),ss[N];inti,j;FILE*fp;fp=fopen(',student.datn,^wb");fwrite(t,sizeof(STU),5,fp);fclose(fp);printf(M\n\nTheoriginaldata:\n\nn);for(j=0;j<N;j++){printf(u\nNo:%ldName:%-8sScores:",t[j].sno,t[j].name);for(i=0;i<3;i++)printf(M%6.2fn,t[j].score[i]);printf(''\n,');)funC^tudent.dat1');printf(H\n\nThedataaftersorting:\n\nM);fp=fopen(',student.dat,\"rbu);fread(ss,sizeof(STU),5,fp);fclose(fp);for(j=0;jvN;j++){printf("\nNo:%ldName:%-8sScores:M,ss[j].sno,);for(i=0;i<3;i++)printf(H%6.2fss[j].score[i]);printf(n\nn);))解题思路:本题是考察把结构中的数据写入文件。第•处:建立文件的类型,考虑到是把结构中的数据(结构中的数据包含不打印的字符)从文件中读出,所以应填:"rb'o第二处:判断当前学号是否大于刚读出的学号进行相比,如果大于,则进行交换,所以应填:>o第三处:把已排序的结构数据,重新写入文件,所以应填:fwriteo给定程序MODI1.C中函数fun的功能是:在字符串的最前端加入n个*号,形成新串,并且覆盖原串。注意:字符串的长度最长允许为79o请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#include<string.h>voidfun(chars[],intn){chara[80],*p;inti;/**********found***********/s=p;for(i=0;i<n;i++)a[i]=*';do{ a[i]=*p;i++;)/**********found***********/while(*p++)a[i]=0;strcpy(s,a);}main(){intn;chars[80];printf(M\nEnterastring:");gets(s);printf(M\nThestringV%sV'\nH,s);printf(M\nEntern(numberof*):");scanf(u%dH,&n);fun(s,n);printf(M\nThestringafterinsert:\H%s\"\nn,s);}解题思路:第•处:指针p应指向s,所以应改为:p=s;o第二处:死循环,当dowhile循环执行一次,临时变量p应该指向字符串的下一位置,所以应改为:while(*p++);o请编写函数fun,函数的功能是:统计各年龄段的人数。N个年龄通过调用随机函数获得,并放在主函数的age数组中;要求函数把0至9岁年龄段的人数放在d⑼中,把10至19岁年龄段的人数放在d[l]中,把20至29岁年龄段的人数放在仇2]中,其余依此类推,把100岁(含100)以上年龄的人数都放在d[10]中0结果在主函数中输出。注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#defineN50#defineM11voidfun(int*a,int*b)|)doublemd(){statict=29,c=217,m=1024,r=0;r=(r*t+c)%m;retum((double)r/m);}main(){intage[N],i,d[M];for(i=0;i<N;i++)age[i]=(int)(115*rnd());printf(HTheoriginaldata:\nu);for(i=0;i<N;i++)printf((i+l)%10==0?,,%4d\n,':,'%4d,",age[iJ);printf(,'\n\nH);fun(age,d);for(i=0;i<10;i++)printf(u%4d—%4d:%4d\n'\i*10,i*10+9,d[i]);printf(HOver100:%4d\nM,d[10]);NONO(d);}解题思路:本题是统计各年龄段的人数。.初始化各年龄段人数为0。.使用for循环以及求出各年龄的十位数字作为存放人数的地址,如果大于值大于10,则存入d[IO]中(大于110岁的人)。参考答案:voidfun(int*a,int*b){inti,j;for(i=0;i<M;i++)b[i]=0;for(i=0;i<N;i++){j=a[i]/10;if(j>10)b[M-1]++;elseb(jj++;})※※※※※※※※※※※※※※※※※※※※※※※第05套:给定程序中,函数fun的功能是将参数给定的字符串、整数、浮点数写到文本文件中,再用字符串方式从此文本文件中逐个读入,并调用库函数atoi和atof将字符串转换成相应的整数、浮点数,然后将其显示在屏幕上。请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#include<stdlib.h>voidfun(char*s,inta,doublef)/**********1ound**********/_1—fp;charstr[100],strl[100],str2[100];intal;doublefl;fp=fopen(,,filel.txt",nwn);fprintf(fp,u%s%d%f\nM,s,a,f);/**********found**********/_2_;fp=fopen(,,filel.txf,,T');/********* nd**********/fscanf(—3—,M%s%s%s'\str,strl,str2);fclose(fp);al=atoi(strl);fl=atof(str2);printf(u\nTheresult:\n\n%s%d%f\nM,str,al,fl);}main(){chara[10]=MHello!M;intb=12345;doublec=98.76;fun(a,b,c);)解题思路:本题是考察先把给定的数据写入到文本文件中,再从该文件读出并转换成相应的整数、浮点数显示在屏幕上。第•处:定义文本文件类型变量,所以应填:FILE*。第二处:关闭刚写入的文件,所以应填:fclose(fp)0第三处:从文件中读出数据,所以应填:fp。给定程序MODI1.C中函数fun的功能是:对Ng学生的学习成绩,按从高到低的顺序找出前m(m<10)名学生来,并将这些学生数据存放在一个动态分配的连续存储区中,此存储区的苜地址作为函数值返回。请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#include<alloc.h>#include<string.h>#defineN10typedefstructss{charnum[10];ints;)STU;STU*fun(STUa[],intm)(STUb[N],*t;intij,k;/**********found**********/t=(STU*)calloc(sizeof(STU),m)for(i=0;i<N;i++)b[i]=a[i];for(k=0;k<m;k++){for(i=j=0;i<N;i++)if(b[i].s>b|j].s)j=i;/**********found**********/t(k)=b(j);b[j].s=O;)returnt;)outresult(STUa[],FILE*pf){inti;for(i=0;i<N;i++)fprintf(pf,nNo=%sMark=%d\n",a[i].num,a[i].s);fprintf(pf;,\n\nn);}main(){STUa[N]={{“A01”,81},{“A02”,89},{“A03”,66},{“A04”,87},{“A05”,77},{“A06”,90},{“A07”,79},{“A08”,61},{“A09”,80},{“A10”,71});STU*pOrder;inti,m;printf(M*****TheOriginaldata*****\n");outresult(a,stdout);printf(n\nGivethenumberofthestudentswhohavebetterscore:");scanf(n%dn,&m);while(m>10){printf(u\nGivethenumberofthestudentswhohavebetterscore:");scanf(,,%d,\&m);}pOrder=fun(a,m);printf(H*****THERESULT*****\nM);printf(nThetop:\nM);for(i=0;i<m;i++)printf(n%s%d\nn,pOrder[i].num,pOrder[i].s);free(pOrder);解题思路:第一处:语句最后缺少分号。第二处:应该使用方括号,而不是圆括号。像此类,使用编译,即可发现。请编写函数fun,函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小到大的顺序排列,函数返回删除后数组中数据的个数。例如,一维数组中的数据是:2223445666677899101010»删除后,数组中的内容应该是:2345678910o注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#defineN80intfun(inta[],intn)()main(){inta[N]={2,2,2,3,4,4,5,6,6,6,6,7,7,8,9,9,10,10,10,10);inti,n=20;printf(HTheoriginaldata:\nH);for(i=0;i<n;i++)printf("%3d”,a[i]);n=fun(a,n);printf(u\n\nThedataafterdeleted:\n");for(i=0;i<n;i++)printf(n%3dM,a[i]);printf(M\n\nn);NONO();}解题思路:本题是删除己排序过数组中的相同数。.取出数组中的第1个数存放在临时变量k中,再利用for循环来依次判断所有的数。.如果取出的数和k相比,如果不相同,则仍存放在原数组中,其中存放的位置由j来控制,接着把这个数重新存入k。如果相同,则取下•数。参考答案:intfun(inta[],intn){inti,j=l,k=a[0];for(i=1;i<n;i++)if(k!=a[i]){ a[j++]=a[i];k=a[i];a[j]=0;returnj;)※※※※※※※※※※※※※※※※※※※※※※※第06套:给定程序中,函数fun的功能是根据形参i的值返回某个函数的值。当调用正确时,程序输出:x1=5.000000,x2=3.000000,xl*xl+xl*x2=40.000000请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>doublefl(doublex){ returnx*x; }doublef2(doublex,doubley){ returnx*y; }/**********^Qund**********/_1_fun(inti,doublex,doubley){if(i==D/**********^^und**********/return_2_(x);else/**********found**********/return_3_(x,y);)main(){doublexl=5,x2=3,r;r=fun(l,xl,x2);r+=fun(2,xl,x2);printf("\nxl=%f,x2=%f,x1*x1+x1*x2=%f\n\n",x1,x2,r);)解题思路:本题是根据给定的公式来计算函数的值。第•处:程序中使用双精度double类型进行计算,所以函数的返回值类型也为double,所以应填:doubleo第二处:当i等于1时,则返回fl函数的值,所以应填:fh第三处:如果i不等于1,则返回f2函数的值,所以应填:f2o给定程序MODI1.C中函数fun的功能是:比较两个字符串,将长的那个字符串的首地址作为函数值返回。请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>/********* nd**********/charfun(char*s,char*t){intsl=O,tl=O;char*ss,*tt;ss=s;tt=t;while(*ss){ sl++;/**********found**********/(*ss)++;)while(*tt){ tl++;/**********found**********/(*tt)++;)if(tl>sl)returnt;elsereturns;)main(){chara[8O],b[8O],*p,*q;inti;printf(H\nEnterastring:");gets(a);printf(n\nEnterastringagain:");gets(b);printf(n\nThelongeris:\n\n\"%s\n\nM,fun(a,b));)解题思路:第一处:试题要求返回字符串的首地址,所以应改为:char*fun(char*s,char*t)第二处:取字符串指针ss的下•个位置,所以应改为:$S++;o第三处:取字符串指针tt的下一个位置,所以应改为:tt++;O请编写函数fun,函数的功能是:移动字符串中的内容,移动的规则如下:把第1到第m个字符,平移到字符串的最后,把第m+1到最后的字符移到字符串的前部。例如,字符串中原有的内容为:ABCDEFGHIJK,m的值为3,则移动后,字符串中的内容应该是:DEFGHIJKABCo注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#include<string.h>#defineN80voidfun1(char*w)/*本函数的功能是将字符串中字符循环左移一个位置*/{inti;chart;t=w[0];for(i=0;i<strlen(w)-1;i++)w[i]=w[i+l];w[strlen(w)-l]=t;)voidfun(char*w,intm)/*可调用funl函数左移字符*/(}main(){chara[N]=,,ABCDEFGHIJKn;intm;printf("Theoriginalstring:\n");puts(a);printf(M\n\nEnterm:M);scanf(M%dM,&m);fun(a,m);printf("\nThestringaftermoving:\n");puts(a);printf(,'\n\nH);NONO();)解题思路:本题是考察字符串的操作。.由于函数funl是将字符串中字符循环左移一个位置,并通过实参w返回循环左移一个位置的字符串。.利用循环for语句来操作多少个字符(m)需要循环左移。参考答案:voidfun(char*w,intm)/*可调用funl函数左移字符*/{inti;fbr(i=0;i<m;i++)funl(w);)※※※※※※※※※※※※※※※※※※※※※※※第07套:程序通过定义并赋初值的方式,利用结构体变量存储了一名学生的信息。函数fun的功能是输出这位学生的信息。请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>typedefstruct{intnum;charname[9];charsex;struct(intyear,month,day;}birthday;floatscore[3];}STU;voidshow(STU 1 ){inti;printf(M\n%d%s%c%d-%d-%d",tt.num,,tt.sex,tt.birthday.year,tt.birthday.month,tt.birthday.day);for(i=0;i<3;i++)/**********found**********/printf(M%5.1f,—2_);printf(u\nn);}main(){STUstd={IJZhanghua",'M',1961,10,8,76.5,78.0,82.0);printfC'\nAstudentdata:\n");/**********found**********/show( 3 );)解题思路:本题是利用结构体变量存储了一名学生的信息。第一处:tt变量在函数体fun已经使用,所以应填:tt.第二处:利用循环分别输出学生的成绩数据,所以应填:tt.score[i]o第三处:函数的调用,所以应填:std。给定程序MODI1.C中函数fun的功能是:求出数组中最大数和次最大数,并把最大数和a[0]中的数对调、次最大数和a[l]中的数对调。请改正程序中的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#defineN20intfun(int*a,intn){inti,m,t,k;for(i=0;i<2;i++)([**********found**********/m=0;for(k=i+l;k<n;k++)/**********nd**********/if(a[k]>a[m])k=m;t=a[i];a[ij=a[m];a[m]=t;))main(){intx,b[N]={11,5,12,0,3,6,9,7.10,8},n=10,i;for(i=0;i<n;i++)printf(H%d",b[i]);printf(n\nH);fun(b,n);for(i=0;i<n;i++)printf(M%d”,b[i]);printf(',\n'');)解题思路:第一处:外循环每循环一次,把当前位置i赋值给m,所以应改为:m=i;»第二处:通过内循环来找出最大的一个数的位置k,所以应改为:if(a[k]>a[m])m=k;.请编写一个函数unsignedfun(unsignedw),w是一个大于10的无符号整数,若w是n(n22)位的整数,函数求出w的低n-1位的数作为函数值返回。例如:w值为5923,则函数返回923;w值为923则函数返回23。注意:部分源程序存在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>unsignedfun(unsignedw)()main(){unsignedx;printf("Enteraunsignedintegernumber:");scanf(H%uH,&x);printf(nTheoriginaldatais:%u\n",x);if(x<10)printf("Dataerror!M);elseprintf("Theresult:%u\nM,fun(x));NONO();)解题思路:本题是考察考生怎样获取•个符合要求的无符号整数。本题是应用if条件语句首先判断给出的数是几位数,再模相应的值,最后得出的余数就是结果。参考答案:unsignedfun(unsignedw){ if(w>10000)w%=10000;elseif(w>1000)w%=1000;elseif(w>100)w%=100;elseif(w>10)w%=10;returnw;)※※※※※※※※※※※※※※※※※※※※※※※※第08套:给定程序通过定义并赋初值的方式,利用结构体变量存储了一名学生的学号、姓名和3门课的成绩。函数fun的功能是将该学生的各科成绩都乘以一个系数a。请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>typedefstruct{intnum;charname[9];floatscore[3];}STU;voidshow(STUtt){inti;printf(n%d%s:n,tt.num,);for(i=0;i<3;i++)printf(,'%5.1f',tt.score[i]);printf(n\nH);)/**********fQund**********/voidmodify( 1 *ss,floata){inti;for(i=0;i<3;i++)/********** nd**********/ss-> 2 *=a;}main(){STUstd={1;'ZhanghuaM,76.5,78.0,82.0};floata;printf(u\nTheoriginalnumberandnameandscores:\n");show(std);printf(M\nInputanumber:");scanf(H%f\&a);/**********found**********/modify(—3—,a);printf(u\nAresultofmodifying:\nu);show(std);)解题思路:本题是利用结构体存储学生记录并由实参SS返回。第•处:实参SS是•个结构型指针变量,所以应填:STU.第二处:该学生的各科成绩都乘以•个系数a,所以应填:score[i]o第三处:函数的调用,由于函数定义时使用的指针结构型变量,所以应填:&std=给定程序M0DI1.C中函数fun的功能是:求k!(k<13),所求阶乘的值作为函数值返回。例如:若k=10,则应输出:3628800.请改正程序中的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>longfun(intk)I /************^0und************/ifk>0return(k*fun(k-l));/************found************/elseif(k=0)returnIL;}main(){intk=10;printf("%d!=%ld\nu,k,fun(k));)解题思路:第一处:条件判断缺少圆括号。第二处:判断相等的符号是=。程序定义了NXN的二维数组,并在主函数中自动赋值。请编写函数fun(intintn),函数的功能是:使数组左下三角元素中的值乘以n。例如:若n的值为3,a数组中的值为I197113971a=l238l则返回主程序后a数组中的值应为169811456111215181注意:部分源程序存在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#include<stdlib.h>#defineN5intfun(inta[][N],intn)(}main(){inta[N][N],n,i,j;printf(*******Thearray*****\nM);for(i=0;i<N;i++){ for(j=0;j<N;j++){a[i]|j]=rand()%10;printf(n%4dM,a[i]|j]);}printfCAn0);}don=rand()%10;while(n>=3);printf(Hn=%4d\nH,n);fun(a,n);printf(M*****THERESULT*****\n");for(i=0;i<N;i++){for(j=0;j<N;j++)printf("%4d",a[i][j]);printf("\n");)NONO();解题思路:本题是利用两重循环给二维数组左卜.三角元素中的值乘以n.参考答案:intfun(inta[][N],intn){inti,j;for(i=0;i<N;i++)for(j=0;j<=i;j++)a[i][j]*=n;)※※※※※※※※※※※※※※※※※※※※※※第09套:给定程序中,函数fun的功能是将不带头节点的单向链表结点数据域中的数据从小到大排序。即若原链表结点数据域从头至尾的数据为:10、4、2、8、6,排序后链表结点数据域从头至尾的数据为:2、4,6、8、10o请在程序的下划线处填入正确的内容并把F划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#defineN6typedefstructnode{intdata;structnode*next;}NODE;voidfun(NODE*h){NODE*p,*q;intt;p=h;while(p){/********************/q=_1_;/**********^ound**********/while(_2_){if(p->data>q->data){t=p->data;p->data=q->data;q->data=t;}q=q->next;)/********** *********/P=_3_;)NODE*creatlist(inta[]){NODE*h,*p,*q;inti;h=NULL;for(i=0;i<N;i++){q=(NODE*)malloc(sizeof(NODE));q->data=a[i];q->next=NULL;if(h==NULL)h=p=q;else{p->next=q;p=q;}}returnh;)voidoutlist(NODE*h){NODE*p;p=h;if(p==NULL)printf("ThelistisNULL!\nM);else{printf(H\nHead");do{ printf(,'->%d",p->data);p=p->next;}while(p!=NULL);printf(n->End\nM);}}main(){NODE*head;inta[N]={0,10,4,2,8,6};head=creatlist(a);printf(M\nTheoriginallist:\nu);outlist(head);fun(head);printf(H\nThelistafterinverting:\nH);outlist(head);}解题思路:本题是考察使用链表方法,使用两重while循环语句,对链表的结点数据进行升序排列。第•处:由于外循环变量使用p指针,内循环变量使用q指针,所以q指向必须指向p的next指针,因此应填写:p->nexto第二处:判断内循环q指针是否结束,所以应填:q»第三处:外循环控制变量p指向自己的next指针,所以应填:p->nexto给定程序MODI1.C中函数fun的功能是:将s所指字符串中的字母转换为按字母序列的后续字母(但Z转换为A,z转换为a),其它字符不变。请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#include<stdlib.h>#include<stdio.h>#include<ctype.h>voidfun(char*s)(/**********found***********/while(*s!=,@,){ if(*s>='A'&*s<=,Z'II*s>=,a,&&*s<=*z'){ if(*s==,Z,)*s=,A,;elseif(*s=='z')*s=a';else*s+=1;)/**********found***********/(*s)++;))main(){chars[80];printf(u\nEnterastringwithlength<80.:\n\n*');gets(s);printf(u\nThestring:\n\n");puts(s);fun(s);printf(H\n\nTheCords:\n\nn);puts(s);}解题思路:第一处:使用while循环来判断字符串指针s是否结束,所以应改为:while(*s)o第二处:取字符串指针s的下•个位置,所以应改为:$++;o请编写函数fun,函数的功能是:移动一维数组中的内容;若数组中有n个整数,要求把下标从。到p(含p,p小于等于n-1)的数组元素平移到数组的最后。例如,・维数组中的原始内容为:1,2,345,6,7,8,9,10;p的值为3。移动后,一维数组中的内容应为:567,8,9,10,1,2,3,4。注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#defineN80voidfun(int*w,intp,intn))main(){inta[N]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15);inti,p,n=15;printf(HTheoriginaldata:\nM);for(i=0;i<n;i++)printf(,,%3d,;a[i]);printf(H\n\nEnterp:M);scanf(,'%d,,,&p);fun(a,p,n);printf("\nThedataaftermoving:\n");for(i=0;i<n;i++)printf(',%3d\a[i]);printf(M\n\nM);NONO();)解题思路:本题是考察一•维数组的操作。.定义一维数组中间变量b,把n值后面数组中的内容存入b中。.再把m前的数组中的内容存入b中。.最后把数组b的内容依次存放到w中。参考答案:voidfun(int*w,intp,intn){inti,j=O,b[NJ;for(i=p+1;i<n;i++)b[j++]=w[i];for(i=0;i<=p;i++)b|j++]=w[i];for(i=0;i<n;i++)w[i]=b[i];}※※※※※※※※※※※※※※※※※※※※※※※第10套:给定程序中,函数fun的功能是:判定形参a所指的NXN(规定N为奇数)的矩阵是否是吆J方",若是,函数返回值为1;不是,函数返回值为0。"幻方"的判定条件是:矩阵每行、每列、主对角线及反对角线上元素之和都相等。例如,以下3X3的矩阵就是一个"幻方":TOC\o"1-5"\h\z4 9 23 5 78 1 6请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#defineN3intfun(int(*a)[N]){ inti,j,m1,m2,row,colum;ml=m2=0;for(i=0;i<N;i++){j=N-i-l;ml+=a[i][i];m2+=a[i][j];}if(ml!=m2)return0;for(i=0;i<N;i++)(/**********found**********/row=colum=_1_;for(j=0;j<N;j++){row+=a[i][j];colum+=a[j][i];}/**********(ound**********/if((row!=colum)_2_(row!=ml))return0;)/********** nd**********/return_3_;}main(){intx[N][N],ij;printf(nEnternumberforarray:\nn);for(i=0;i<N;i++)for(j=0;j<N;j++)scanf(M%dH,&x[i][j]);printf(nArray:\nM);for(i=0;i<N;i++){ for(j=0;j<N;j++)printf(M%3dH,x[i]U]);printf(H\nM);)if(fun(x))printf("TheArrayisamagicsquareAn1');elseprinlf("TheArrayisn'tamagicsquareAn");)解题思路:第一处:行列变量row和colum的值初始化为0。第二处:两个条件只要有个不满足就返回0,所以应填:II。第三处:如果矩阵是“幻方”,则返回1。给定程序MODU.C中fun函数的功能是:根据整型形参m,计算如下公式的值。111t=1 2 3 m例如,若主函数中输入5,则应输出-0.283333。请改正函数fun中的错误或在横线处填上适当的内容并把横线删除,使它能计算出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>doublefun(intm)doublet=1.0;inti;for(i=2;i<=m;i++)t=1.0-1/i;}main(){intm;printf(n\nPleaseenter1integernumbers:\nn);scanf(H%dH,&m);printf(H\n\nTheresultis%lf\nH,fun(m));)解题思路:第•处:在除法运算中,如果除数和被除数都是整数,所么所除结果也是整数,因此应改为第二处:应是返回公式的值,函数中公式的值是存放在临时变量t中,所以应填returnt;。请编写一个函数,函数的功能是删除字符串中的所有空格。例如,主函数中输入"asdafaaz67",则输出为"asdafaaz67"«注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#include<ctype.h>intfun(char*str)()main(){charstr[81];intn;printf("Inputastring:");gets(str);puts(str);fun(str);printf("***str:%s\n",str);NONO();)解题思路:本题是考察考生怎样利用字符串指针来删除字符串的空格字符。在函数开始处把指针p先指向字符串str以及位置变量i置0,然后采用while循环和字符串指针p来处理的,每循环一次来判断指针p所指的字符是否为空格,如果不是空格,则把该字符写到str字符串中,位置由i来控制,如果是空格,则不处理,继续取下一字符,直至字符串结束为止,最后再把字符串结束符写到位置为i的str上,再通过形参str返回。参考答案:intfun(char*str){char*p=str;inti=0;while(*p){if(*P!='*)str[i4-+]=*p;p++;)str[i]=0;}※※※※※※※※※※※※※※※※※※※※※※第n套:给定程序中,函数fun的功能是将带头结点的单向链表逆置。即若原链表中从头至尾结点数据域依次为:2、4、6、8、10,逆置后,从头至尾结点数据域依次为:10、8、6、4、2o请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的BLANK1.C中。不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#include<stdlib.h>#defineN5typedefstructnode{intdata;structnode*next;}NODE;voidfun(NODE*h){NODE*p,*q,*r;/亭*********found**********/p=h->_1_;/**********found**********/if(p==_2_)return;q=p->next;p->next=NULL;while(q){r=q->next;q->next=p;/**********found**********/p=q;q=_3_;)h->next=p;}NODE*creatlist(inta[J){NODE*h,*p,*q;inti;h=(NODE*)malloc(sizeof(NODE));h->next=NULL;for(i=0;i<N;i++){q=(NODE*)malloc(sizeof(NODE));q->data=a[i];q->next=NULL;if(h->next==NULL)h->next=p=q;else{p->next=q;p=q;}}returnh;)voidoutlist(NODE*h){NODE*p;p=h->next;if(p==NULL)printf(HThelistisNULL!\nH);else{printf(n\nHead");do{ printf(,'->%d",p->data);p=p->next;}while(p!=NULL);printf(',->End\nM);))main(){NODE*head;inta[N]={2,4,6,8,10};head=creatlist(a);printf(*'\nTheoriginallist:\nu);outlist(head);fun(head);printf(,'\nThelistafterinverting:\nu);outlist(head);)解题思路:本题是考察使用链表方法,对链表的结点数据进行降序排列。第一处:使用结构指针p,来控制链表的结束,P必须指向h结构指针的next指针,来定位p的初始位置。所以应填写:h->next»第二处:判断P指针是否结束,所以应填写:0o第三处:q指向原q的next指针,所以应填:r。给定程序MODI1.C中函数fun的功能是:计算s所指字符串中含有t所指字符串的数目,并作为函数值返回。请改正函数fun中指定部位的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!给定源程序:#include<stdio.h>#include<string.h>#defineN80

intfun(char*s,char*t){intn;char*p,*r;n=0;while(*s){P=s;/*********found**********/r=p;while(*r)if(*r==*p){r++;p++;)elsebreak;/*********found**********/if(*r=0)n++;s++;)returnn;)main(){chara[N],b[N];intm;printf(M\nPleaseenterstringa:");gets(a);printf(n\nPleaseentersubstringb:");gets(b);m=fun(a,b);printf("\nTheresultis:m=%d\n'\m);}解题思路:第一处:程序中子串是由变量t来实现的,再根据下面while循环体中语句可知,所以应改为:r=t;o第二处:是判断相等的条件,所以应改为:if(*r=O)。请编写函数fun,函数的功能是:将放在字符串数组中的M个字符串(每串的长度不超过N),按顺序合并组成一个新的字符串。函数fun中给出的语句仅供参考。例如,字符串数组中的M个字符串为AAAABBBBBBBCC则合并后的字符串的内容应是:AAAABBBBBBBCC。提示:strcat(a,b)的功能是将字符串b复制到字符串a的串尾上,成为一个新串。注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。给定源程序:#include<stdio.h>#defineM3#defineN20voidfun(chara[M][N],char*b){inti;*b=0;main(){charw[M][N]={nAAAA,,/,BBBBBBBM;'CC,,),a[100];inti;printf(uThestring:\n*');for(i=0;i<M;i++)puts(w[i]);printf(''\n,');fun(w,a);printf("TheAstring:\n,');printf(''%s'\a);printf(',\n\nn);NONO();)解题思路:本题是考察字符串的操作。使用for循环以及C语言函数slrcat依次连接起来。参考答案:#include<stdio.h>#defineM3#defineN20voidfun(chara[M][N],char*b){ /*以下代码仅供参考*/inti;*b=0;for(i=0;i<M;i++)strcat(b,a[i]);}※※※※※※※※※※※※※※※※※※※※※※※※第12套:给定程序中,函数fun的功能是将不带头结点的单向链表逆置。即若原链表中从头至尾结点数据域依

温馨提示

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

评论

0/150

提交评论