电大-C语言程序设计形成性考核册答案缩写本_第1页
电大-C语言程序设计形成性考核册答案缩写本_第2页
电大-C语言程序设计形成性考核册答案缩写本_第3页
电大-C语言程序设计形成性考核册答案缩写本_第4页
电大-C语言程序设计形成性考核册答案缩写本_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

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

文档简介

生命赐给我们,我们必须奉献生命,才能获得生命。一、选择题1.在每个C语言程序中都必须包含有这样一个函数,该函数的函数名为(A)。A.mainB.MAINC.nameD.funtionA)。2.C语言原程序文件的缺省扩展名为(D.CA.cppB.exeC.obj3.由C语言目标文件连接而成的可执行的缺省扩展名为(B)。B.exeC.objD.CA.cpp4.程序运行中需要从键盘输入多于一个数据时,各数据之间应使用(D)符号作为分隔符。C.回A.空格或逗号B.逗号或回车车或分号D.空格或回车B)类。5.每个C语言程序的编译错误分为(D.4A.1B.2C.36.设x和y均为逻辑值,则x&&y为真的条件是(A)。A.它们均为真B.其中一个为真C.它们均为假D.其中一个为假7.设有语句“inta=12;a+=a*a;”,则执行结束后,a的值为(C)。B.144C.156DA.12.288的相反表达式为(A)。8.x>0&&x<=10A.x<=0||X>10B.x<=0&&D.x>0&&x>10C.x<=0||x<=10x>109.字符串“a+b=12\n”的长度为(B)。D.9A.6B.7C.810.在下列符号常量定义中。错误的定义语句格式为(C)。A.constM1=10;B.constintcharmark=’M2=20;C.constM310D.const3’;11.带有随机函数的表达式rand()%20的值在(C)区间内,B.1~20C.0~19A.1~19D.0~2012.当处理特定问题时的循环次数已知时,通常采用(A)循环来解决。A.for B.while C.do-whileD.switch13.在switch 语句的每个 case块中,假定都是以 break语句结束的,则此switch语句容易被改写为(B)语句。A.forB.ifC.doD.whileD)语句。14.for语句能够被改写为(A.复B.ifC.switchD合.whilei值为(B)。15.下面循环语句执行结束后输出的for(inti=0;i<n;i++)if(i>n/2){cout<<i<<endl;break;}A.n/2B.n/2+1C.n/2-1D.n-116.在下面循环w语句中内层循环体S语句的执行次数为(D)。for(inti=0;i<n;i++)A.n2for(intj=i;j<n;j++)S;C.n(n-1)/2B.(n+1)/2D.n(n+1)/217.在下面的do循环语句中,其循环体被执行的次数为(A)。inti=0;doi++;while(i*i<10);C.5D.2A.4B.3在下面的一维数组定义中,(C)语句有语法错误。A.inta[]={1,2,3};B.inta[10]={0};C.inta[];D.inta[5];nC)语句是正确的。2.在下面的二维数组定义中,(A.inta[5][];B.inta[][5];C.inta[][3]={{1,3,5},{2}};D.inta[](10)3.假定一个二维数组的定义语句为“int

a[3][4]={{3,4},{2,8,6}}; ”,则元素a[1][2] 的值为(C)。A.2 B.4 C.6 D.84.假定一个二维数组的定义语句为“inta[3][4]={{3,4},{2,8,6}};”,则元素a[2][1]的值为(A)。A.0B.4C.8D.65.将两个字符串连接起来组成一个字符串时,选用(C)函数。B.strcap()C.strcatA.strlen()()D.strcmp()选择题在下面的(C)函数声明语句存在语法错1.误。A.,int)AA(intC.AA(inta,intb);B.AA(inta;intb)D.AA(inta,int)2.在下面的(C)不能作为函数的返回类型。A.voidB.intC.newD.longB)。3.下面正确的函数原型语句是(B.voidA.intFunction(voida);Function(int);D.voidC.intFunction(a);int(doublea);4.函数调用func(exp1,exp2),exp3*exp4-exp5)中所含实参的个数为(B)个。C.4D.5A.1B.25.下面的标识符中,(C)是文件级作用域。C.外部静A.函数形参B.语句标号态类标识符D.自动类标识符6.下面的标识符中,(B)具有全局级作用域。A.函数形参B.全局变量C.内部静态类标识符D.自动变量符p+1所指7.假定p是一个指向float型数据的指针,则数据的地址比p所指数据的地址大(C)字节。D.8A.1B.2C.48.假定a为一个字符数组名,则a[8]的地址比该数组的首地址大(B)个字节。C.16D.32A.4B.89.假定a为一个数组名,则下面的(B)表示有错误。A.a[i]B.*a++C.*aD.*(a+1)10个整型元素的一维数组的10.用calloc函数创建具有正确语句是(C)。B.intA.int*p=calloc(10,2);*p=callo(10;D.intC.int*p=calloc(10,4);*p=malloc(10);”,则定义p的正确语11.假定变量m定义为“intm=7;句为(B)。B.int*p=&m;C.intA.intp=&m;&p=*m;D.int*p=m;k的12.假定k是一个double类型的变量,则定义指向变量p的正确语句为(B)。BdoubleA.doublep=&k;.*p=&k;C.double&p=*k;D.char*p=”Thankyou!”;13.假定一条定义语句为“inta[10],x,*pa=a;”,若要把数组a中下标为3的元素赋值给x,则不正确的语句为(D)。A.x=pa[3];B.x=*(a+3);C.a=a[3];D.x=*pa+3;14.假定有定义“intb[10];int*pb;”,则不正确的赋值语句为(C)。C.pb=b+2;A.pb=b;B.pb=&b[0];D.pb=b[5];15.假定指针变量p定义为“int*p=newint(100);”,要释放p所指向的动态内存,应使用语句(D)。A.delete[p];B.delete*p;C.delete&p;D.delete[]p;p定义为“int16.假定指针变量*p=calloc(30,sizeof(int));”,要释放p所指向的动态希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。生命赐给我们,我们必须奉献生命,才能获得生命。内存,应使用语句( D )。A.delete[p]; B.deldete(p); C.free[]p; D.free(p);选择题假定有“structBOOK{chartitle[40];floatprice;};structBOOK*book;”,则不正确的语句为(A)。A.structBOOK*x=malloc(book);B.structBOOKx={“C++Programming”,27.0};C.structBOOK*x=malloc(sizeof(BOOK));D.structBOOK**x=&book;price;}2.假定有“structBOOK{chartitle[40];floatbook;”,则正确的语句为(B)。A.structBOOKB.structBOOKx=&book;*x=&book;D.structC.structBOOKx=calloc(BOOK);BOOK*x=BOOK;C)。3.表示文件结束的符号常量为(A.eofB.EofC.EOFD.feof是(D)一个数据文件的函4.C语言中系统函数fopen()数。B.写入C.关A.读取闭D.打开5.从一个数据文件中读入以换行符结束的一行字符串的函数为(B)。B.fgets()C.getc()A.gets()D.fgetc()fwrite()带有(D)6.向一个二进制文件写入信息的函数参数。B.2C.3A.1D.4单选题(每小题 2分,共20分)由C语言源程序文件编译而成的目标文件的默认扩展名为(D)。A.cppB.cC.exeD.obj为假的条件是x2.设x和y均为逻辑值,则x||y和y(C)。A.均为真B.其中一个为真C. 均为假 D. 其中一个为假枚举类型中的每个枚举常量的值都是一个A)。A. 整数 B. 浮点数 C. 字符记录

A.stderr B.stdin C.stdoutstdio二、填空题1.C语言中的每条简单语句以___;_______作为结束符。2.C语言中的每条复合语句以___}_______作为结束符。3.在C语言程序的每个程序行后面或单独一行的开始使用注释的标记符为___//___。4.单行或多行注释的结束标记符为__*/_____。5.在一个C程序文件中,若要包含另外一个头文件或程序文件,则应使用以__#include___标识符开始的预处理命令。6.在#include命令中所包含的头文件,可以是系统定义的头文件,也可以是__用户___定义的头文件。7.一个函数定义由__函数头______和函数体两部分组成。8.用于输出表达式的标准输出函数是_printf()_________。9.当不需要函数返回任何值时,则应使用__void_______标识符定义函数类型。10.执行“printf(“%d-%d=%d”,43,18,43-18);”语句后得到的输出结果为__43-18=25_______。11.每个C程序文件在编译时可能出现有警告性错误,其对应的标识符为__warning______。12.每个C程序文件在编译时可能出现有致命性错误,其对应的标识符为__error______。13.十进制数25表示成符合C语言规则的十六进制数为___0x19___。14.在C语言中,转义字符序列___\n___表示一个换行符。15.执行“printf(“%c”,’F’-2);”语句后得到的输出结果为__D___。16.已知’A’~’Z’的ASCII码为65-90,当执行“intx=’C’+5;”语句所x的值为___72___.17.假定一个枚举类型的定义为“enumRB{ab,ac=3,ad,ae}x=ad;”,则x的值为___4___.18.char类型的大小为__1__个字节。19.int类型的大小为__4__个字节。20.float类型的大小为__4__个字节。21.十进制数28类型为___int___。22.十进制数3.26类型为___double___。23.若需要定义一个符号常量,并且使C语言能够进行类型检查,则应在定义语句的开始使用保留字____const___。24.使用const语句定义一个符号常量时,则必须对它同时进行__定义类型和赋初值__。25.执行“intx=45,y=13;printf( “%d”,x%y);”语句4.循环语句“for(i=0;i<=n;i++)S;”中循环体S序列后得到的输出结果为___6__。被执行的次数为(D)。26.假定x=5,则表达式2+x++的值为__7__。A.1B.n-1C.n27.表达式(float)25/4的值为___6.25___。D.n+1假定有语句为“inta[4][5]={{1,3,5},{2,8}};28.表达式(int)14.6%5的值为___4___。5.”,29.表达式x=x+1表示成增量表达式为__x++___。则a[1][1]的值为(C)。30.增量表达式++y表示成赋值表达式为___y+=1__。A.3B.5C.831.关系表达式(x!=0)的等价表达式为____x___。D.1032.假定不允许使用逻辑非操作符,则关系表达式x+y>56.在下面的选项中,不能作为函数的返回值类型的的相反表达式为___x+y<=5__。a>b||是(B)。33.假定不允许使用逻辑非操作符,则逻辑表达式A.voidB.nodeC.intb==5的相反表达式为___a<=b&&(b>5||b<5)____。D.long假定x的值为5,y的值为6,则表达式x++*--y34.若x=5,y=10,则x>y逻辑值为___false___。7.35.若x=5,y=10,则x<=y逻辑值为___true___。的值为(A)。C.3636.假定x=5,则执行“a=(x?10:20);”语句后a的值为A.25B.30__10__。DataType;”语句后,在使用intD.42用calloc函数创建具有1037.执行“typedefint8.个整型元素的动态存定义整型变量的地方都可以使用___DataType___来定义储空间的正确调用是(C)。B.整型变量。case后A.calloc(10,sizeof(char))38.在switch语句中,每个语句标号所含保留字calloc(10)calloc(10,sizeof(int))D.面的表达式必须是__整型__。C.39.作为语句标号使用的C保留字case和default只能calloc(20,sizeof(int))用于__switch__语句的定义体中。9.假定有语句“intb[10],*pb;”,则不正确的赋40.在switch语句时,在进行作为条件的表达式求值后,值为(B)。C.pb=b+2将从某个匹配的标号位置起向下执行,当碰到下一个标号A.pb=bB.pb=b[5]位置时(停止/不停止)___不停止__执行。D.pb=&b[0]B41.若do循环的“尾”为“while(++i<10)”,并且i的10.标准输入设备的文件流标识符是()。初值为0,同时在循环体不会修改i的值,由循环体将被重复执行__10___次后正常结束。希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。生命赐给我们,我们必须奉献生命,才能获得生命。42.当在程序执行到___break___语句时,将结束本层循环语句或switch语句的执行。43.在程序中执行到__return__语句时,将结束所在函数的执行过程,返回到调用该函数的位置。44.在程序执行完 __主(main)__函数调用后,将结束整个程序的执行过程,返回到操作系统或C语句集成开发环境界面窗口。二、填空题char*a[8];1.假定一维数组的定义为“”,则该数组所含元素的个数为___8_______。2.假定一维数组的定义为“char*a[8];”,则该数组所占存储空间的字节数为___32______。3.假定二维数组的定义为“inta[3][5]”,则该数组所占存储空间的字节数为___60______。4.假定二维数组的定义为“chara[M][N];”,则该数组所所含元素的个数为__M*N_____。a[M][N];”,则每5.假定二维数组的定义为“double个数组元素的行下标取值范围在__0~M-1___之间。6.假定二维数组的定义为“doublea[M][N];”,则每个数组元素的列下标取值范围在__0~N-1___之间。7.使用“typedefcharBB[10][50];”语句定义__BB______为含有10行50列的二维字符数组类型。8.存储字符’a’需要占用存储器的 _1_____个字节空间。9.空字符串的长度为 __0_______。10.存储一个空字符串需要占用 __1___个字节。11.字符串”数据”的长度为___11______。12.用于存储一个长度为n的字符串的字符数组的长度至少为__n+1______。___大小比较13.strcmp函数用于进行两个字符串之间的___。___复制到___另一个字14.Strcpy函数用于把一个字符串符数组空间中。a[10][20]能够存储__10___个字15.一个二维字符数组符串。a[10][20]16.一个二维字符数组能够存储的每个字符串的长度至多为___19___.二、填空题___函数体_______1.在C语言中,一个函数由函数头和组成。2.在函数外定义的变量称为全局变量,若没有被初始化则系统隐含对它所赋的初值为___0______。3.如果一个函数只允许同一程序文件中的函数调用,则应在访函数定义前加上的C保留字为为___static______。4.如果一个函数直接或间接地调用自身,这样的调用被称为__递归_____调用。#include5.调用系统函数时,要先使用命令包含该函数的原型语句所在__头___文件。__内部___。6.函数形参的作用域是该函数的7.假定p所指对象的值为 25,p+1所指对象的值为 46,则*p++的值为__25______。8.假定p所指对象的值为 25,p+1所指对象的值为 46,则*++p的值为__46______。9.假定p所指对象的值为25,p+1所指对象的值为46,则执行“*(p++);”语句后,p所指对象的值为__46______。10.假定a是一个指针数组,则a+1所指对象的地址比a地址大__4___字节。11.若要把一个整型指针 p转换为字符指针,则采用的强制转换表达式为___(char*)p______。12.假定一个数据对象为int*类型,则指向该对象的指针类型为__int**______。___&p___表13.假定p是一个指向整数对象的指针,则用示指针变量p的地址。14.若p指向x,则___*p___与x的等价的。15.NULL是一个符号常量,通常作为空指针值,它值为__’\0’(ASCII码0)_24__字节。二、填空题1.假定一个结构类型的定义为“structA{inta,b;A*c;};”,则该类型的大小为_12__字节。2.假定一个结构类型的定义为“structB{inta[5],char*b;};”,则该类型的大小为

3.假定一个结构类型的定义为“structD{inta;union{intb;doublec;};structD*d[2];};”,则该类型的大小为___20_______字节。的具有n4.假定要动态分配一个类型为structWorker个元素的数组,并由r指向这个动态数组,则使用语句的表达式为structWorker*r=__(Worker*)malloc(n*sizeof(Worker));_____ 。5.假定要访问一个结构 x中的由a指针成员所指向的对象,则表示方法为__x.(*a)___。b指针成6.假定要访问一个结构指针p所指向对象中的员所指的对象,则表示方法为__*(p->b)___7.与结构成员访问表达式(*fp).score等价的表达式是__fp->score______。二、填空题(每小题2分,共26分)在一个C语言程序文件中,若要包含另外一个头文件或程序文件,则应使用的预处理命令为___#include__。用于从键盘上为变量输入值的标准输入函数的函数名为_scanf__。假定一个枚举类型的定义为“enumRA{ab,ac,ad,ae};”,则ad的值为_2__。.int类型的长度为__4__。5. 执行“intx=45,y=8;printf("%d",x/y); ”语句序列后得到的输出结果为 __5__。把表达式x=x+y转换成复合赋值表达式为__x+=y___。假定x的值为5,则执行“a=(x>=6?3:8);”语句后a的值为___8_____。8. 假定一维字符指针数组的定义为“ char*a[5]; ”,则该数组占用的存储空间的字节数为 __20______。9. 假定二维数组的定义为“ doublea[M][N]; ”,则数组元素的行下标取值范围在 __0~M-1_______之间。空字符串的长度为__0______。在所有函数定义之外定义的变量,若没有被初始化则系统隐含对它所赋的初值为____0____。若p指向x,则____*p____与x的表示是等价的。直接访问表达式(*fp).score所对应的间接访问表达式为__fp→score____。三、写出下列每个程序运行后的输出结果#include<stdio.h>voidmain(){intx=5;switch(2*x-3){case4:printf("%d",x);case7:printf("%d",2*x+1);case10:printf("%d",3*x-1);break;default:printf("%s","default\n");}printf("%s\n","switchend.");}输出结果为:1114switchend.Pressanykeytocontinue#include<stdio.h>voidmain(){inti,s=0;for(i=1;i<=6;i++)s+=i*i;printf("s=%d\n",s);}输出结果为:s=91.Pressanykeytocontinue#include<stdio.h>voidmain()希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。生命赐给我们,我们必须奉献生命,才能获得生命。{{inti,s1=0,s2=0;inti,c2,c3,c5;for(i=0;i<10;i++)if(i%2)s1+=i;c2=c3=c5=0;elses2+=i;for(i=1;i<=M;i++){}printf("%d%d\n",s1,s2);if(i%2==0)c2++;if(i%3==0)c3++;输出结果为:if(i%5==0)c5++;2520.}Pressanykeytocontinueprintf("%d%d%d\n",c2,c3,c5);4.#include<stdio.h>}voidmain()输出结果为:{1064intn=10,y=1;Pressanykeytocontinuewhile(n--){y++;y++;}8.#include<stdio.h>printf("y=%d\n",y);}#include<math.h>输出结果为:constintM=20;y=21.voidmain()Pressanykeytocontinue{inti,s;for(i=1,s=0;i<15;i++){if(i%2==0||i%3==0)continue;printf("%d",i);s+=i;5.#include<stdio.h>}printf("%d\n",s);voidmain()}{输出结果为:intf,f1,f2,i;157111337f1=f2=1;Pressanykeytocontinueprintf("%d%d",f1,f2);三、写出下列每个程序运行后的输出结果for(i=3;i<=10;i++){1.#include<stdio.h>f=f1+f2;voidmain()printf("%d",f);{if(i%5==0)printf("\n");intf1=f2;a[10]={12,39,26,41,55,63,72,40,83,95};}f2=f;inti,i1=0,i2=0;for(i=0;i<10;i++)printf("\n");if(a[i]%2==1)i1++;else}i2++;输出结果为:printf("%d%d\n",i1,i2);11235}813213455输出结果为:Pressanykeytocontinue646.#include<stdio.h>Pressanykeytocontinue2.#include<stdio.h>#include<math.h>voidmain()#include<string.h>{voidmain()inti,n;{for(n=2;n<=20;n++){inti;intchartemp=(int)sqrt(n);//sqrt(n)求出n的平方根并取整*a[5]={"student","worker","cadre","soldier","peasfor(i=2;i<=temp;i++)ant"};)break;if(n%i==0char*p1,*p2;if(i>tempp1=p2=a[0];)printf("%d",n);for(i=0;i<5;i++){if(strcmp(a[i],p1)>0)p1}=a[i];printf("\n");if(strcmp(a[i],p2)<0)p2}=a[i];输出结果为:}235711131719printf("%s%s\n",p1,p2);Pressanykeytocontinue}7.#include<stdio.h>输出结果为:workercadre#include<math.h>PressanykeytocontinueconstintM=20;3.#include<stdio.h>voidmain()希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。生命赐给我们,我们必须奉献生命,才能获得生命。inta[10]={4,5,6,15,20,13,12,7,8,9};voidmain(){inti,s0,s1,s2;s0=s1=s2=0;for(i=0;i<10;i++){switch(a[i]%3){case0:s0+=a[i];break;case1:s1+=a[i];break;case2:s2+=a[i];break;}}printf("%d%d%d\n",s0,s1,s2);}输出结果为:422433Pressanykeytocontinue#include<stdio.h>voidmain(){chara[]="abcdbfbgacd";inti1=0,i2=0,i=0;while(a[i]){if(a[i]=='a')i1++;if(a[i]=='b')i2++;i++;}printf("%d%d%d\n",i1,i2,i);}输出结果为:2311Pressanykeytocontinue#include<stdio.h>voidmain(){int a[3][4]={{1,2,7,8},{5,6,10,6},{9,12,3,4}};intm=a[0][0];intii=0,jj=0;inti,j;for(i=0;i<3;i++)for(j=0;j<4;j++)if(a[i][j]>m){m=a[i][j];ii=i;jj=j;}printf("%d%d%d\n",ii,jj,a[ii][jj]);}输出结果为:2112Pressanykeytocontinue#include<stdio.h>voidmain(){inta,b;for(a=1,b=2;b<50;){printf("%d%d",a,b);a=a+b;b=a+b;}printf("\n");}输出结果为:12358132134Pressanykeytocontinue四、写出下列每个函数的功能#include<stdio.h>intSA(inta,intb){

if(a>b)return1;elseif(a==b)return0;elsereturn-1;}函数功能为:b,返回1,0或-1根据实参a大于、等于或小于实参#include<stdio.h>intSC(inta,intb,intc){if(a>=b&&a>=c)returna;if(b>=a&&b>=c)returnb;returnc;}函数功能为:返回实参 a、b、c中的最大数3.doubleSF(doublex,intn){//n 为大于等于 0的整数doublep=1,s=1;for(i=1;i<=n;i++){p*=x;s+=p/(i+1);}returns;}函数功能为:计算x+x2/2+x3/3+ +xn/(n+1) 的值#include<math.h>intSC(intx){inta=(int)sqrt(x);inti=2;while(i<=a){if(x%i==0)break;i++;}if(i<=0)return0;elsereturn1;}函数功能为:判断一个整数是否是素数#include<stdio.h>voidtrans(intx){chara[10];inti=0,rem;do{rem=x%16;x=x/16;if(rem<10)a[i]=48+rem;//'0'字符的ASCII码为48elsea[i]=65+rem;//'A'字符的ASCII码为55i++;}while(x!=0);while(i>0)printf("%c",a[--i]);}printf("\n");函数功能为:将一个整数化成十六进制数五、根据下列每个题目要求编写程序voidfun4(char*a,1.编写一个函数,函数头格式为“intb[])”,分别求出由字符指针a所指向的字符串中包含的每种十进制数字出现的次数,把统计结果保存在数组的相应元素。#include<stdio.h>voidfun4(char*a,intb[]){do{if(*a>='0' &&*a<='9')b[*a-48]++;}while(*a++);}希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。生命赐给我们,我们必须奉献生命,才能获得生命。2. 编写一个函数,函数头格式为“doubleMean(double 三、写出下列每个程序运行后的输出结果a[M][N] ,int m,int n)”,要求返回二维数组 a[m][n] 1.#include<stdio.h>中所有元素的平均值, 假定在计算过程是采用变量 v存放 voidSB(charch){平均值。switch(ch){#include<stdio.h>case'A':case'a':constintM=2,N=3;printf("WW");break;doubleMean(doublea[M][N],intm,intn){case'B':case'b':doublev=0;printf("GG");break;for(inti=0;i<m;i++)case'C':case'c':for(intj=0;j<n;j++)v+=a[i][jprintf("PP");break;];default:printf("BB");break;}returnv/(m*n);}}voidmain(){3.编写一个递归函数“intFF(inta[],intn)”,chara1='b',a2='C',a3='f';SB(a3);SB求出数组a中所有元素n个元素之积并返回。SB(a1);SB(a2);#include<stdio.h>('A');intFF(inta[],intn){printf("\n");intmul=1;}if(n==1)mul*=a[0];输出结果为:elsemul=a[n-1]*FF(a,n-1);GGPPBBWWreturnmul;Pressanykeytocontinue}编写一个主函数,利用while循环,求出并显示满足不等式1+1/2+1/3++1/n>5的最小n值。#include<stdio.h>voidmain(){doublesum=0;intn=1;while(true){if(sum+1/(double)n>5)break;elsesum +=1/(double)n;n++;}printf("%d,%lf\n",n,sum);}编写一个主函数,求满足不等式22+42++n2<1000的最大n值,假定分别用i和s为取偶数值和累加值的变量,并限定使用do循环编程。#include<stdio.h>voidmain(){ints=0,i=2;do{s+=i*i;if(s+(i+2)*(i+2)>=1000)break;elsei+=2;}while(true);printf("i=%d,s=%d",i,s);}编写一个主函数,计算并输出n的值,其中n值由键盘输入。#include<stdio.h>voidmain(){ints=0,n;printf("请输入n的值:");scanf("%d",&n);for(inti=1;i<=n;i++)s+=i*i;printf("n=%d,s=%d",n,s);}

#include<stdio.h>#include<stdlib.h>doubleSD(inta,intb,charop){doublex;switch(op){case'+':x=a+b;break;case'-':x=a-b;break;case'*':x=a*b;break;case'/':if(b)x=(double)a/b;elseexit(1);break;default:{(" 运算符错!\n");exit(1);}}returnx;}voidmain(){intx=20,y=8;printf("%3.2lf",SD(x,y,'-'));printf("%3.2lf",SD(x,y,'*'));printf("%3.2lf",SD(x,y,'/'));}输出结果为:12.00160.002.50Pressanykeytocontinue#include<stdio.h>voidWF(intx,inty){x=x+y;y=x+y;printf("subs:x,y=%d,%d\n",x,y);}voidmain(){intx=18,y=23;printf("main:x,y=%d,%d\n",x,y);WF(x,y);x=2*x;printf("main:x,y=%d,%d\n",x,y);}输出结果为:main:x,y=18,23subs:x,y=41,64main:x,y=36,23Pressanykeytocontinue#include<stdio.h>#include<string.h>voidfun(charss[]) ;voidmain(){希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。生命赐给我们,我们必须奉献生命,才能获得生命。chars[15]="567891234";5060fun(s);Pressanykeytocontinue}printf("%s\n",s);8.#include<stdio.h>voidfun(charss[]){intLB(int*a,intn){;inti,n=strlen(ss);inti,s=1for(i=0;i<n/2;i++){for(i=0;i<n;i++)s*=*a++;charc=ss[i];returns;ss[i]=ss[n-1-i];}}ss[n-1-i]=c;voidmain(){}inta[]={1,2,3,4,2,4,5,2};intb=LB(a,4)+LB(&a[3],4);输出结果为:printf("b=%d\n",b);432198765}Pressanykeytocontinue输出结果为:5.#include<stdio.h>b=184PressanykeytocontinuevoidInsertSort(inta[],intn){inti,j,x;四、写出下列每个函数的功能进行n次循环1.#include<stdio.h>for(i=1;i<n;i++){//intWB(inta[],intn,intx){x=a[i];for(inti=0;i<n;i++)for(j=i-1;j>=0;j--)//为if(a[i]==x)return1;x顺序向前寻找合适的插入位置if(x>a[j]}return0;)a[j+1]=a[j];else函数功能为:x,返回1或0break;根据整型数组元素中是否能找到整数a[j+1]=x;2.#include<stdio.h>}}intWC(inta[],intn,intk){intc=0;for(inti=0;i<n;i++)voidmain()if(a[i]>=k)c++;{inti;}returnc;inta[6]={20,15,32,47,36,28};函数功能为:InsertSort(a,6);返回数组中前n个其值大于等于k的元素之和for(i=0;i<6;i++)printf("%d",a[i]);3.#include<stdio.h>}printf("\n");#include<stdlib.h>#include<time.h>输出结果为:constintN=10;473632282015intff(intx,inty){Pressanykeytocontinueintz;printf("%d+%d=",x,y);6.#include<stdio.h>scanf("%d",&z);voidmain(){inta[8]={3,5,7,9,11,13,15,17};if(x+y==z)return1;elsereturn0;}inti,*p=a;voidmain()for(i=0;i<8;i++){;printf("%5d",*p++);{if((i+1)%4==0)printf("\n");inti,a,b,c=0;//初始化随机数}}srand(time(0));系列输出结果为:579for(i=0;i<N;i++){//3a=rand()%20+1;11131517rand90函数产生0-32767之间的一个随机数Pressanykeytocontinueb=rand()%20+1;7.#include<stdio.h>}c+=ff(a,b);intLA(int*a,intn){得分:%d\n",c*10);inti,s=0;printf("for(i=0;i<n;i++)}returns;s+=a[i];函数功能为:}函数ff让两个数相加,要求输入其和,判断结果是否正确。在主函数中用随机函数产生两个20以内的随机整数,voidmain(){通过10次调用这个函数,算对一次得10分,计算所得分4.intfun6(intm,intn,intb=2)inta[]={5,10,15,20,25,30};{intb=LA(a,4);if(m<b&&n<b)returnm*n;intc=LA(a+2,3);elseif(m%b==0&&n%b==0)return}printf("%d%d\n",b,c);b*fun6(m/b,n/b,b);elsereturnfun6(m,n,++b);输出结果为:}希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。生命赐给我们,我们必须奉献生命,才能获得生命。floatpay;//工资函数功能为:此函数带有一个默认参数,若使用默认值,则通过递归调};用,返回前2参数的最小公倍数;2个参数,则voidmain(){不使用默认值时,若最后一个参数不小于前structWorkerx;返回前2参数之乘积;n倍数。char*t="louting";否则,通过递归调用,返回前2参数最小公倍数的intd=38;floatf=493;5.#include<stdio.h>strcpy(,t);#include<stdlib.h>x.age=d;x.pay=f;voidLI(intn){*a=(intx.age++;x.pay*=2;intprintf("%s%d%6.2f\n",,x.age,*)malloc(n*sizeof(int));x.pay);inti;}for(i=0;i<n;i++)scanf("%d",a+i);for(i=n-1;i>=0;i--)printf("%d输出结果为:",*(a+i));louting39986.00printf("\n");Pressanykeytocontinuefree(a);}函数功能为:将从键盘输入的 n个整数逆序输出#include<stdio.h>intLK(doublea[],intn){doubles=0;inti,m=0;for(i=0;i<n;i++)s+=a[i];s/=n;for(i=0;i<n;i++)if(a[i]>=s)m++;returnm;}函数功能为:求不小于数组元素之平均值的各元素之和(前n个)应加入此4字,否则D亦对cannotconvertfrom必须强制类型转换!否则提示'void*'to'int*'三、写出下列每个程序运行后的输出结果#include<stdio.h>structWorker{charname[15];//姓名intage;//年龄};floatpay;//工资voidmain(){structWorkerx={"wanghua",52,23.50};structWorkery,*p;y=x;p=&x;y.pay);printf("%s%d%6.2f\n",,y.age,printf("%s%d%6.2f\n",p->name,p->age,p->pay);}输出结果为:23.50wanghua52wanghua5223.50Pressanykeytocontinue2.#include<stdio.h>#include<string.h>structWorker{charname[15];// 姓名intage; // 年龄

3.#include<stdio.h>#include<string.h>structWorker{charname[15];// 姓名intage; // 年龄floatpay;// 工资};intLess(structWorkerr1,structWorkerr2){if(r1.age<r2.age)return1;elsereturn0;}voidmain(){structWorkera[4]={{"abc",25,420},{"def",58,638},{"ghi",49,560},{"jkl",36,375}};structWorkerx=a[0];inti;for(i=1;i<4;i++)if(Less(x,a[i]))x=a[i];printf("%s%d%6.2f\n",,x.age,x.pay);}输出结果为:def58638.00Pressanykeytocontinue四、写出下列每个函数的功能1.voidQA(structWorkera[],intn){inti;for(i=0;i<n;i++)scanf("%s%d%f",&a[i].name,a[i].age,a[i].pay);}假定结构 structWorker 的定义如下:#include<stdio.h>#include<stdlib.h>#include<string.h>structWorker{charname[15];//姓名intage;//年龄floatpay;//工资};函数功能为:类型的对象a[n]的各个元素的值输入structWorker2.structStrNode*QB(intn){StrNode* f,*p;if(n==0)returnNULL;f=(StrNode*) malloc(sizeof(structStrNode));scanf("%s",f->name);p=f;希望是本无所谓有,无所谓无的。这正如地上的路;其实地上本没有路,走的人多了,也便成了路。生命赐给我们,我们必须奉献生命,才能获得生命。while(--n){p=p->next=(StrNode*)malloc(sizeof(structStrNode));scanf("%s",p->name);}p->next=NULL;returnf;}假定结构 structStrNode 的定义如下:structStrNode{charname[5];structStrNode*next;};函数功能为:建立一个具有n个结点,每个结点的类型是StrNode的链表structIntNode*FindMax(structIntNode*f){structIntNode*p=f;if(!f)returnNULL;f=f->next;while(f){if(f->data<p->data)p=f;f=f->next;}returnp;}假定结构 structStrNode 的定义如下:structIntNode{intdata;structIntNode*next;};函数功能为:在一个具有n个结点,每个结点的类型是IntNode的链表中寻找data值最大的结点intCount(structIntNode*f){intc=0;while(f){c++;f=f->next;}returnc;}假定结构 structStrNode 的定义如下:structIntNode{intdata;structIntNode*next;};函数功能为:计算一个具有n个结点,每个结点的类型是IntNode的链表的结点数structIntNode*Input(intn){structIntNode*f,*p;f=(IntNode*)malloc(sizeof(structIntNode));if(n==0)returnNULL;f->next=NULL;printf("从键盘输入%d个整数:",n);while(n--){scanf("%d",&(f->data));p=f;f=(IntNode*)mall

温馨提示

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

评论

0/150

提交评论