C语言函数习题及答案_第1页
C语言函数习题及答案_第2页
C语言函数习题及答案_第3页
C语言函数习题及答案_第4页
C语言函数习题及答案_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

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

文档简介

第6章函数习题一、选择题一个完整的C源程序是【】。A)要由一个主函数或一个以上的非主函数构成B)由一个且仅由一个主函数和零个以上的非主函数构成C)要由一个主函数和一个以上的非主函数构成D)由一个且只有一个主函数或多个非主函数构成以下关于函数的叙述中正确的是【】。A)C语言程序将从源程序中第一个函数开始执行B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束D)main可作为用户标识符,用以定义任意一个函数以下关于函数的叙述中不正确的是【】。A)C程序是函数的集合,包括标准库函数和用户自定义函数B)在C语言程序中,被调用的函数必须在main函数中定义C)在C语言程序中,函数的定义不能嵌套D)在C语言程序中,函数的调用可以嵌套在一个C程序中,【】。A)main函数必须出现在所有函数之前B)main函数可以在任何地方出现C)main函数必须出现在所有函数之后D)main函数必须出现在固定位置若在C语言中未说明函数的类型,则系统默认该函数的数据类型是【】A)floatB)longC)intD)double以下关于函数叙述中,错误的是【】。A)函数未被调用时,系统将不为形参分配内存单元B)实参与形参的个数应相等,且实参与形参的类型必须对应一致C)当形参是变量时,实参可以是常量、变量或表达式D)形参可以是常量、变量或表达式C程序中各函数之间可以通过多种方式传递数据,下列不能用于实现数据传递的方式是【】。A)参数的形实(哑实)结合B)函数返回值C)全局变量D)同名的局部变量若函数调用时参数为基本数据类型的变量,以下叙述正确的是【】。A)实参与其对应的形参共占存储单元B)只有当实参与其对应的形参同名时才共占存储单元C)实参与对应的形参分别占用不同的存储单元D)实参将数据传递给形参后,立即释放原先占用的存储单元函数调用时,当实参和形参都是简单变量时,他们之间数据传递的过程是【】。A)实参将其地址传递给形参,并释放原先占用的存储单元B)实参将其地址传递给形参,调用结束时形参再将其地址回传给实参C)实参将其值传递给形参,调用结束时形参再将其值回传给实参D)实参将其值传递给形参,调用结束时形参并不将其值回传给实参若函数调用时的实参为变量时,以下关于函数形参和实参的叙述中正确的是【】。A)函数的实参和其对应的形参共占同一存储单元B)形参只是形式上的存在,不占用具体存储单元C)同名的实参和形参占同一存储单元D)函数的形参和实参分别占用不同的存储单元若用数组名作为函数调用的实参,则传递给形参的是【】。A)数组的首地址B)数组的第一个元素的值C)数组中全部元素的值D)数组元素的个数若函数调用时,用数组名作为函数的参数,以下叙述中正确的是【】。A)实参与其对应的形参共用同一段存储空间B)实参与其对应的形参占用相同的存储空间C)实参将其地址传递给形参,同时形参也会将该地址传递给实参D)实参将其地址传递给形参,等同实现了参数之间的双向值的传递如果一个函数位于C程序文件的上部,在该函数体内说明语句后的复合语句中定义了一个变量,则该变量【】。A)为全局变量,在本程序文件范围内有效B)为局部变量,只在该函数内有效C)为局部变量,只在该复合语句中有效D)定义无效,为非法变量C语言中函数返回值的类型是由【】决定。A)return语句中的表达式类型B)调用函数的主调函数类型C)调用函数时临时D)定义函数时所指定的函数类型若在一个C源程序文件中定义了一个允许其他源文件引用的实型外部变量a,则在另一文件中可使用的引用说明是【】。A)externstaticfloata;B)floata;C)externautofloata;D)externfloata;定义一个void型函数意味着调用该函数时,函数【】A)通过return返回一个用户所希望的函数值B)返回一个系统默认值C)没有返回值D)返回一个不确定的值若定义函数float*fun(),则函数fun的返回值为【】。A)—个实数B)—个指向实型变量的指针C)一个指向实型函数的指针D)—个实型函数的入口地址C语言规定,程序中各函数之间【】。A)既允许直接递归调用也允许间接递归调用B)不允许直接递归调用也不允许间接递归调用C)允许直接递归调用不允许间接递归调用D)不允许直接递归调用允许间接递归调用若程序中定义函数floatmyadd(floata,floatb){returna+b;}并将其放在调用语句之后,则在调用之前应对该函数进行说明。以下说明中错误的是【】。}}A)floatmyadd(floata,b);floatmyadd(floatb,floata);floatmyadd(float,float);floatmyadd(floata,floatb);关于以下fun函数的功能叙述中,正确的是【】。intfun(char*s){char*t=s;while(*t++);t--;return(t-s);}A)求字符串s的长度B)比较两个串的大小C)将串s复制到串tD)求字符串s所占字节数下面程序段运行后的输出结果是【】(假设程序运行时输入5,3回车)inta,b;voidswap(){intt;t=a;a=b;b=t;}main(){scanf("%d,%d",&a,&b);swap();printf("a=%d,b=%d\n",a,b);}A)a=5,b=3B)a=3,b=5C)5,3D)3,5以下程序运行后的输出结果是【】。fun(inta,intb){if(a>b)returna;elsereturnb;}main(){intx=3,y=8,z=6,r;r=fun(fun(x,y),2*z);printf("%d\n",r);}A)3B)6C)8D)12以下程序的运行结果是【】。voidf(inta,intb){intt;t=a;a=b;b=t;main(){intx=1,y=3,z=2;if(x>y)f(x,y);elseif(y>z)f(x,z);elsef(x,z);printf("%d,%d,%d\n",x,y,z);}A)1,2,3B)3,1,2C)1,3,2D)2,3,1以下程序运行后的输出结果为【】。int*f(int*x,int*y){if(*x<*y)returnx;elsereturny;}main(){inta=7,b=8,*p,*q,*r;p=&a,q=&b;r=f(p,q);printf("%d,%d,%d\n",*p,*q,*r);}A)7,8,8B)7,8,7C)8,7,7D)8,7,8以下程序的正确运行结果是【】。#inclued<stdio.h>main(){intk=4,m=1,p;p=func(k,m);printf(“%d”,p)p=func(k,m);printf(“%d\n”,p)}func(inta,intb){staticintm=0,i=2;i+=m+1;m=i+a+b;return(m);}A)8,17B)8,16C)8,20D)8,826.以下程序的功能是计算函数F(x,y,z)=(x+z)/(y-z)+(y+2Xz)/(x-2Xz)的值,请将程序补充完整。#include<stdio.h>floatf(floatx,floaty){floatvalue;value=【1】;returnvalue;}main(){floatx,y,z,sum;scanf("%f%f%f",&x,&y,&z);sum=f(x+z,y-z)+f(【2】);printf("sum=%f\n",sum);}【1】A)x/yB)x/zC)(x+z)/(y-z)D)x+z/y-z【2】A)y+2z,x-2zB)y+z,x-zC)x+z,y-zD)y+z*z,x-2*z27.以下程序的功能是根据输入的字母,在屏幕上显示出字符数组中首字符与其相同的字符串,若不存在,则显示“Nofind,goodbye!”,请将程序补充完整。#include<stdio.h>charPriStr(charch1){inti=0,j=0;staticchar*ch2[]={"howareyou","gladtomeetyou","anythingnew","everythingisfine","verywell,thankyou","seeyoutomorrow"};while(i++<6)if(ch1==【1】){puts(【2】);j=1;}returnj;}main(){charch;printf("\nPleaeenterachar:");ch=getchar();ch=PriStr(ch);if(ch==【3】)puts("Nofind,goodbye!");}1】A)ch2[i][0]B)ch2[i-1][0]C)*ch2[i]D)*ch2[i-1][0]2】A)ch2[i]B)*ch2[i]C)*ch2[i-1]D)ch2[i-1]3】A)'0'B)'48'C)0D)3028.以下程序是将输入的一个整数反序打印出来,例如输入1234,则输出4321,输入-1234,则输出-4321。请将程序补充完整。voidprintopp(longintn){inti=0;if(n==0)return;elsewhile(n){if(【1】)printf("%ld",n%10);elseprintf("%ld",-n%10);i++;【2】;}}main(){longintn;scanf("%ld",&n);printopp(n);printf("\n");}【1】A)n<0&&i==0B)n<0||i==0C)n>0&&i==0D)n>0||i==0【2】A)n%=10B)n%=(-10)C)n/=10D)n/=)-10)下面的程序用递归定义的方法实现求菲波拉契数列1、1、2、3、5、8、13、21……第7项的值fib(7),菲波拉契数列第1项和第2项的值都是1。请将程序补充完整。#include<stdio.h>longfib(【1】){switch(g){case0:return0;case1:case2:return1;}return(【2】);}main(){longk;k=fib(7);printf("k=%d\n",k);}【1】A)gB)kC)longintgD)intk【2】A)fib(7)B)fib(g)C)fib(k)D)fib(g-1)+fib(g-2)有以下程序intfun(intn){if(n==1)return1;elsereturn(n+fun(n-1));}main(){intx;scanf("%d",&x);x=fun(x);printf("%d\n",x);}程序执行时,若输入10,程序的输出结果是【】。55B)54C)65D)45下面是一个计算1至m的阶乘并依次输出的程序。程序中应填入的正确选项是【】。#include<stdio.h>doubleresult=1;factorial(intj){result=result*j;return;}main(){intm,i=0,x;printf("Pleaseenteraninteger:");scanf("%d",&m);for(;i++<m;){x=factorial(i);printf("%d!=%.0f\n",【】);}}i,factorial(i)B)i,xC)j,xD)i,result以下程序的功能是求任意两个整数a和b的最大公约数,并予以显示。请将程序补充完整。#include<stdio.h>#include<stdlib.h>longcodivisor(longn1,longn2){longt;while(n2!=0){【1】;n1=n2;n2=t;}return(【2】);}main(){longa,b,x;printf("pleaseinputtwonumbers:");scanf("%ld%ld",&a,&b);x=codivisor(a,b);printf("maximumcommondivisorof%ldand%ldis:%ld\n",a,b,x);}【1】A)t=n1/n2B)t=n1%n2C)t=n2%n1D)t=n2/n1【2】A)labs(n1)B)labs(a)C)labs(b)D)labs(n2)

以下程序的功能是计算并显示一个指定行数的杨辉三角形(形状如下),请将程序补充完整。111TOC\o"1-5"\h\z12113311464115101051程序:#include<stdio.h>#defineN15voidyanghui(intb[][N],intn){inti,j;for(i=0;【1】;i++){b[i][0]=1;b[i][i]=1;}for(【2】;++i<=n;)for(j=1;j<i;j++)b[i][j]=【3】;for(i=0;i<n;i++){for(j=0;j<=i;j++)printf("%4d",b[i][j]);printf("\n");}}main(){inta[N][N]={0},n;printf("pleaseinputsizeofyanghuitriangle(<=15)");scanf("%d",&n);printf("\n");yanghui(a,n);C)C)i<nD)i<=nC)i=2D)i=3B)b[i-2][j-1]+b[i-1][j]D)b[i-2][j-2]+b[i-1][j]1】A)i<NB)i<=N2】A)i=0B)i=13】A)b[i-1][j-1]+b[i-1][j]C)b[i-1][j-1]+b[i-1][j+1]下面的程序用来将一个十进制正整数转化成八进制数,例如输入一个正整数25,则输出31,请将程序补充完整。#include<stdio.h>main(){inti=0,j=0,a,b[10]={0};printf("\nPleaseinputainteger:");scanf("%d",&a);sub(a,b);for(;i<10;i++){if(【1】)j++;if(j!=0)printf("%d",b[i]);}}sub(intc,intd[]){inte,i=9;while(c!=0){e=c%8;d[i]=e;【2】;i--;}return;}【1】A)b[i]<0B)b[i-1]!=0C)b[i]<=0D)b[i]!=0【2】A)c=sub(c/8)B)c=c%8C)c=c/8D)c=e%8函数bisearch的作用是应用折半查找法从存有N个整数的升序数组a中对关键字key进行查找。请将程序补充完整。#include<stdio.h>#defineN15bisearch(inta[N],intkey){intlow=0,high=N-1,mid;while(【1】){mid=(low+high)/2;if(key<a[mid])【2】;elseif(key>a[mid])low=mid+1;elsereturnmid;}return【3】;}main(){intb[N],n,I,j;printf("Pleaseinputa%delementincreasingsequence:",N);

for(i=0;i<N;i++){printf("b[%d]=",i);scanf("%d",&b[i]);}printf("Pleaseinputasearchingkey:");scanf("%d",&n);j=bisearch(b,n);if(j<-5)printf("Don'tfind%d\n",n);elseprintf("b[%d]=%d\n",j,n);1】A)low<high21】A)low<high2】A)high=mid-13】A)0low!=highlow=mid+1-10low<=highhigh=mid+1-1low<=high-1low=mid-1D)1如果程序及其运行结果显示如下,请将程序补充完整。21046152324785132Thevalueis15.程序:#include<stdio.h>func(【1】){int【2】,j;for(j=0;j<4;j++){b[3][j]=2*b[0][j];printf("%4d",b[3][j]);b[3][j]=0;}printf("\n");for(j=0;j<4;j++)if(b[i][j]<5&&b[i][2]>5)k+=b[i][j];returnk;}main(){staticinta[4][4]={【3】};inti,j,k;k=func(a,9);for(i=0;i<4;i++){for(j=0;j<4;j++)if(a[i][j]!=0)printf("%4d",a[i][j]);if(a[i][4]!=0)printf("\n");}printf("Thevalueis%d\n",k);}【1】A)intb[4][],kB)intb[][4],kC)intb[4,4],intkD)intb[][4],intk【2】A)i=0B)i=1C)i=2D)i=3【3】A){1,5,2,3},{2,4,7,8},{5,1,3,2}B){2,10,4,6},{1,5,2,3},{2,4,7,8},{5,1,3,2}C){1,5,2,3},{2,4,7,8},{5,1,2,3}D){2,10,4,6},{1,5,2,3},{2,4,7,8},{5,1,2,3}37.以下程序的功能是用二分法求方程f(x)=x41+x3+1=0在区间(-1.0,-0.5)中的一个实根,并要求绝对误差不超过0.001。二分法的基本思想是:假设在区间(a,b)中f(a)与f(b)异号,先取区间的中点m,如果f(m)与f(a)异号,则取新的解区间为(a,m),否则取新的解区间为(m,b)。不断对解区间对分,直到解区间已经小于给定的误差时,取该区间的中点作为解的近似值。请将程序补充完整。#include<stdio.h>#include<math.h>floatf(floatx){return(pow(x,41)+pow(x,3)+1);}floatsolv(floata,floatb){floatm;m=(a+b)/2;while(f(m)*f(b)!=0){if(【1】)a=m;elseb=m;if(【2】)break;m=(a+b)/2;}returnm;}main(){floatr;r=solv(-1.0,-0.5);printf("approximatesolutionoff(x)=0is%ff(%f)=%.6f\n",r,r,【3】);}【1】A)f(m)*f(b)<0B)f(m)*f(b)>=0C)f(m)*f(b)<=0D)f(m)*f(b)>0【2】A)b-a<0.001B)fabs(a-b)<0.001C)ABS(a-b)<0.001D)a-b<0.001【3】A)f(r)B)f(m)C)rD)m38.以下程序是选出能被3整除且至少有一位是5的所有三位正整数k(个位为a0,十位为al,百位为a2),打印出所有这样的数及其个数。请将程序补充完整。

#include<stdio.h>sub(intm,intn){inta0,a1,a2;a2=【1】;a1=【2】;a0=m%10;if(m%3==0&&(a2==5||a1==5||a0==5)){printf(“%d”,m);n++;}returnn;}main(){intm=0,k;for(k=105;k<=995;k++)m=sub(【3】);printf("\nn=%d\n",m);}1】A)m/10B)m%10C)m/100D)m%1002】A)(m-a2*10)/10B)m/10-a2*10C)m%10-a2*10D)m%100-m%103】A)k,mB)m,kC)k,nD)n,k39.以下程序可计算10名学生1门课成绩的平均分,要求使用无返回值函数实现。请将程序补充完整。#include<stdio.h>voidaverage(floatarray[10]){inti=0;while(【1】)array[0]+=【2】;array[i-1]=array[0]/10;}main(){floatscore[10];inti;printf("Pleaseinput10scores:\n");for(i=0;i<10;i++)scanf("%f",&score[i]);average(score);printf("Theaveragescoreis%.2f\n",【3】);}1】A)i<=10i++<10++i<102】}1】A)i<=10i++<10++i<102】A)array[i-1]array[i]array[i--]3】A)score[8]B)score[0]C)array[8]i<10D)array[i++]score[9]40.以下程序用于输入不超过N个数的整数序列(用-1作为输入结束标志),然后统计出从M1至M2各数在序2.2.列中出现的次数并显示输出。请将程序补充完整。#include<stdio.h>#defineN100#defineM13#defineM27main(){inta[N],c[M2-M1+1]={0},i,n=0,x=0;printf("Pleaseinputasequenceofnumber(%d-%d)whichisendedwith-1:\n",M1,M2);while(x!=-1){scanf("%d",&x);a[n]=x;n++;}f(a,c,n);printf("Repeatingtimesof%d-%dinsequenceofnumberis:\n",M1,M2);for(i=0;i<=M2-M1;i++)printf(“%d:%d\n”,【1】);printf("\n");}f(【2】){inti;for(i=0;i<n;i++)if(a[i]>=M1&&a[i]<=M2)3】;}1}1】A)M1+i:c[M1+i]B)M1+i+1:c[i]C)C)M1+i:c[i]i:c[M1+i]2】2】A)f(a[],c[],n)B)f(inta[],intc[],intn)C)f(a,c,n)3C)f(a,c,n)3】A)c[a[i]]++C)a[c[i]]++

二.读程序写结果D)f(inta[N],c[M2-M1+1],n)B)c[a[i]-M2]++D)c[a[i]-M1]++1.fun(intx,inty,intz){z=x*x+y*y;}main(){inta=31;fun(6,3,a);printf("%d",a);}intf(){staticinti=0;ints=1;s+=i;i++;returns;}main(){inti,a=0;for(i=0;i<5;i++)a+=f();printf("%d\n",a);}运行程序时,若从键盘输入asdafaaz67(回车),分析以下程序的输出结果。#include<stdio.h>intfun(char*str){inti,j=0;for(i=0;str[i]!='';i++)if(str[i]!='')str[j++]=str[i];str[j]='';}main(){charstr[81];intn;printf("Inputastring:");gets(str);fun(str);printf("%s\n",str);}4.voidswap(int*p1,int*p2){int*t;t=p1,p1=p2,p2=t;printf("*p1=%d,*p2=%d\n",*p1,*p2);}main(){intx=10,y=20;swap(&x,&y);printf("x=%d,y=%d\n",x,y);}5.#include<stdio.h>voidfun(int*s,intm,intn)intt;while(m<n){t=s[m];s[m]=s[n];s[n]=t;m++;n--;}}main(){Inta[5]={1,2,3,4,5},k;fun(a,0,4);for(k=0;k<5;k++)printf("%d",a[k]);}6.intfun(chars[]){intn=0;while(*s<='9'&&*s>='0'){n=10*n+*s-'0';s++;}return(n);}main(){chars[10]={'6','1','*','4','*','9','*','0','*'};printf("%d\n",fun(s));}7.#include<stdio.h>Intfun(intx){inty;if(x==0||x==1)return(3);y=x*x-fun(x-2)returny;}main(){intx,y;x=fun(3);y=fun(4);printf("%d,%d\n",x,y);}8.fun(intn,int*s){intf1,f2;if(n==1||n==2)*s=1;else{fun(n-1,&f1);fun(n-2,&f2);*s=f1+f2;}}main(){intx;fun(6,&x);printf("%d\n",x);}三、填空题以下程序实现了计算X的n次方,请将程序填写完整。floatpower(floatx,intn){inti;floatt=1;for(i=1;i<=n;i++)t=t*x;【1】;}main(){floatx,y;intn;scanf("%f,%d",&x,&n);y=power(x,n);printf("%8.2f\n",y)?;}以下程序实现了求两个数的最大公约数,请将程序填写完整。intdivisor(inta,intb){intr;r=a%b;while(【2】){a=b;b=r;r=a%b;}returnb;}voidmain(){inta,b,d,t;scanf("%d%d",&a,&b);if(a<b){t=a;a=b;b=t;}d=divisor(a,b);printf("\ngcd=%d",d);}以下函数my_cmp()的功能是比较字符串s和t的大小,当s等于t时返回0否则返回s和t的第一个不同字符的ASCII码差值,即s>t时返回正值,s<t时返回负值。请将函数填写完整。my_cmp(char*s,char*t){while(*s==*t){if(【3】)return0;++s;++t;}return【4】;}以下程序的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小到大的顺序排列,函数返回删除后数组中数据的个数。请将程序填写完整。例如,若一维数组中的数据是:2223445666677899101010删除后,数组中的内容应该是:2345678910。#include<stdio.h>#defineN80intfun(inta[],intn){inti,j=1;for(i=1;i<n;i++)if(a[j-1]【5】a[i])a[j++]=a[i];return【6】;}main(){inta[N]={2,2,2,3,4,4,5,6,6,6,6,7,7,8,9,9,10,10,10},i,n=19;printf("Theoriginaldata:\n");for(i=0;i<n;i++)printf(“%d”,a[i]);n=fun(a,n);printf("\nThedataafterdeleted:\n");for(i=0;i<n;i++)printf(“%d”,a[i]);}四、编程题1.请用自定义函数的形式编程实现,求s=m!+n!+k!,m、n、k从键盘输入(值均小于7)。2.请用自定义函数的形式编程实现求10名学生1门课程成绩的平均分。3.请编写两个自定义函数,分别实现求两个整数的最大公约数和最小公倍数,并用主函数调用这两个函数,输出结果(两个整数由键盘输入得到)。4.已知二阶Fibonacci数列:「0若n=0Fib(n)彳1若n=1-Fib(n-l)+Fib(n-2)其他情况请编写一个递归函数,实现求Fib(n)。22.第6章一、选择题1.B2.C3.B4.B5.C6.D7.D8.C9.D10.D11.A12.A13.C14.D15.D16.C17.B18.A19.A20.A21.A22.

温馨提示

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

评论

0/150

提交评论