C语言程序设计填空题及答案复习用
更新时间:2023-12-26 22:05:01 阅读量: 教育文库 文档下载
导读:在程序填空题中,已经给出了程序的主干,读者首先要理解程序的思路,再选择正确的内容填入空白处,使程序完成既定的功能。这类习题的设计就是要引导读者逐步掌握编程的方法。本节习题的难度适中,可能有些典型的程序在课堂上已经有所接触,读者一定要独立完成它,这样就可以逐步提高自己的编程能力。在程序设计语言学习的中期,读者对程序设计已经有了初步的了解,而自己编写程序又不知从何处入手,此时解答此类题目可以避免盲目性,从而提高学习的效率。
【3.1】下面程序的功能是不用第三个变量,实现两个数的对调操作。
#include
scanf(\;
printf(\; a= ① ; b= ② ; a= ③ ;
printf(\; }
【3.2】下面程序的功能是根据近似公式:π2/6≈ 1/12+1/22+1/32+ …… +1/n2,求π值。 #include
for(i=1;i<=n;i++) s=s+ ① ; return( ② ); }
【3.3】下面的程序的功能是求一维数组中的最小元素。 findmin(int *s,int t,int *k) { int p;
for(p=0,*k=p;p } main() { int a[10],i,*k=&i; for(i=0;i<10;i++) scanf(\; findmin(a,10,k); printf(\; } 【3.4】下面程序的功能是计算1-3+5-7+ …… -99+101的值。 main() { int i,t=1,s=0; for(i=1;i<=101;i+=2) { ① t=t* i; s=s+t; ② ;t>0?t=-1:1; } printf(\; } 【3.5】有以下程序段: s=1.0; for(k=1;k<=n;k++) s=s+1.0/(k*(k+1)); printf(\; 填空完成下述程序,使之与上述程序的功能完全相同。 s=0.0; ① ; k=0; do { s=s+d; ② ; d=1.0/(k*(k+1)); }while( ③ ); printf(\; 【3.6】下面程序的功能是从键盘上输入若干学生的学习成绩,统计并输出最高成绩和最低成绩,当输入为负数时结束输入。 main() { float x,amax,amin; scanf(\; amax=x; amin=x; while( ① ) { if(x>amax) amax=x; if( ② ) amin=x; scanf(\; } printf(\; } 【3.7】下面程序的功能是将形参x的值转换为二进制数,所得的二进制数放在一个一维数组中返回,二进制数的最低位放在下标为0的元素中。 fun(int x,int b[]) { int k=0,r; do { r=x% ① ; b[k++]=r; x/= ② ; }while(x); } 【3.8】下面程序的功能是输出1到100之间每位数的乘积大于每位数的和的数。例如数字26,数位上数字的乘积12大于数字之和8。 main() { int n,k=1,s=0,m; for(n=1;n<=100;n++) { k=1; s=0; ① ; while( ② ) { k*=m; s+=m; ③ ; } if(k>s) printf(\; } } 【3.9】下面程序的功能是统计用0至9之间的不同的数字组成的三位数的个数。 main() { int i,j,k,count=0; for(i=1;i<=9;i++) for(j=0;j<=9;j++) if( ① ) continue; else for(k=0;k<=9;k++) if( ② ) count++; printf(\; } 【3.10】下面程序的功能是输出100以内的个位数为6、且能被3整除的所有数。 main() { int i,j; for(i=0; ① ;i++) { j=i*10+6; if( ② ) countinue; printf(\; } } 【3.11】下面程序的功能是用辗转相除法求两个正整数m和n的最大公约数。 hcf(int m,int n) { int r; if(m ③ ; } 【3.12】下面程序的功能是使用冒泡法对输入的10个浮点数从小到大进行排序。排好序的10个数分两行输出。程序如下: #include printf(\; for(i=0; ② ;i++ ) scanf(\; printf(\; for(i=2; ③ ;i++ ) for(j=0; ④ ;j++ ) if( ⑤ ) { x=a[j]; ⑥ ; a[j+1]=x; } printf(\;\\n\; for(i=0; ⑦ ;i++ ) { if( ⑧ ) printf(\; printf(\; } printf(\; } 【3.13】下面程序的功能是读入20个整数,统计非负数个数,并计算非负数之和。 #include \main() { int i,a[20],s,count; s=count=0; for(i=0;i<20;i++ ) scanf(\① ); for(i=0;i<20;i++) { if(a[i]<0) ② ; s+=a[i]; count++; } printf(\; } 【3.14】下面程序的功能是删除字符串s中的空格。 #include { char *s=\; int i,j; for(i=j=0;s[i]!='\\0';i++) if(s[i]!= ' ') ① ; else ② ; s[j]= '\\0'; printf(\; } 【3.15】下面程序的功能是将字符串s中所有的字符'c'删除。请选择填空。 #include { char s[80]; int i,j; gets(s); for(i=j=0;s[i]!= '\\0';i++ ) if(s[i]!= 'c') ① ; s[j]= '\\0'; puts(s); } 【3.16】下面程序的功能是输出两个字符串中对应相等的字符。请选择填空。 #include char x[]=\; char y[]=\; main() { int i=0; while(x[i]!= '\\0' && y[i]!= '\\0') if(x[i]==y[i]) printf(\① ); else i++; } 【3.17】下面程序的功能是将字符串s中的每个字符按升序的规则插到数组a中, 字符串a已排好序。 #include { char a[20]=\; char s[]=\; int i,k,j; for(k=0;s[k]!= '\\0';k++ ) { j=0; while(s[k]>=a[j] && a[j]!= '\\0' ) j++; for( ① ) ② ; a[j]=s[k]; } puts(a); } 【3.18】下面程序的功能是对键盘输入的两个字符串进行比较,然后输出两个字符串中第一个不相同字符的ASCII码之差。例如:输入的两个字符串分别为 \和\,则输出为-1。 #include { char str1[100],str2[100],c; int i,s; printf(\; gets(str1); printf(\; gets(str2); i=0; while((str1[i] == str2[i] && str1[i]!= ① )) i++; s= ② ; printf(\; } 【3.19】下面的函数expand在将字符串s复制到字符串t时, 将其中的换行符和制表符转换为可见的转义字符表示,即用'\\n'表示换行符,用'\\t'表示制表符。 expand(char s[],char t[]) { int i,j; for(i=j=0;s[i]!= '\\0';i++ ) switch (s[i]) { case '\\n': t[ ① ] = ② ; t[j++] = 'n'; break; case '\\t': t[ ③ ] = ④ ; t[j++] = 't'; break; default: t[ ⑤ ] = s[i]; break; } t[j] = ⑥ ; } 【3.20】下面的函数index(char s[], char t[])检查字符串s中是否包含字符串t,若包含,则返回t在s中的开始位置(下标值),否则送回-1。 index(char s[], char t[]) { int i,j,k; for(i=0;s[i]!= '\\0';i++ ) { for(j=i,k=0; ① && s[j]==t[k];j++,k++) ; if( ② ) return (i); } return(-1); } n 【3.21】下面程序的功能是计算S= k! 。 k=0 long fun(int n) { int i; long s; for(i=1;i ① ;i++) s*=i; return( ② ); } main() { int k,n; long s; scanf(\; s= ③ ; for(k=0;k<=n;k++) s+= ④ ; printf(\; } 【3.22】下面程序的功能是显示具有n个元素的数组s中的最大元素。 #define N 20 main() { int i,a[N]; for(i=0;i fmax(int s[],int n) { int k,p; for(p=0,k=p;p 【3.23】下面程序的功能是由键盘输入n,求满足下述条件的x、y: return( y ); } main() { double x; printf(\; scanf(\; printf(\; } 【3.28】组合问题,由组合的基本性质可知: (1) C(m,n)=C(n-m,n) (2) C(m,n+1)=C(m,n)+C(m-1,n) 公式(2)是一个递归公式,一直到满足C(1,n)=n为止。当n<2*m时,可先用公式(1) 进行简化,填写程序中的空白,使程序可以正确运行。 nx和ny的末3位数字相同,且x≠y,x、y、n均为自然数,并使x+y为最小。 #include for(last=1,i=1;i<=x;i++ ) last= ① ; return(last); } main() { int x,n,min,flag=1; scanf(\; for(min=2;flag;min++) for(x=1;x if( ② && pow3(n,x)==pow3(n,min-x)) { printf(\; ③ ; } } 【3.24】下面的程序是用递归算法求a的平方根。求平方根的迭代公式如下: #include double mysqrt( double a, double x0 ) { double x1, y; x1 = ① ; if( fabs(x1-x0)>0.00001 ) y = mysqrt( ② ); else y = x1; } 【3.25】以下程序是计算学生的年龄。已知第一位最小的学生年龄为10岁,其余学生的年龄一个比一个大2岁,求第5个学生的年龄。 #include if( n==1 ) c=10; else c= ① ; return(c); } main() { int n=5; printf(\② ); } 【3.26】下面的函数sum(int n)完成计算1~n的累加和。 sum(int n) { if(n<=0) printf(\; if(n==1) ① ; else ② ; } 【3.27】下面的函数是一个求阶乘的递归调用函数。 facto(int n) { if( n == 1 ) ① ; else return( ② ); #include\main() { int m,n; printf(\; scanf(\; printf(\combin(m,n)); } combin( int m, int n) { int com; if( n<2*m ) m=n-m; if( m==0 ) com=1; else if(m==1) ① ; else ② ; return(com); } 【3.29】下列函数是求一个字符串str的长度。 ?????? int strlen( char *str ) ??????{ if( ① ) return (0); ?? ???? else return ( ② ); } 【3.30】用递归实现将输入小于32768的整数按逆序输出。如输入12345,则输出54321。 #include\main() { int n; printf(\; scanf(\① ); r(n); printf(\; } r( int m ) { printf(\② ); m = ③ ; if( ④ ) ⑤ ; } 【3.31】输入n值,输出高度为n的等边三角形。例如当n=4时的图形如下: * *** ***** ******* #include { printf( \; ① ; } } main() { int i, n; scanf(\; for( i=1; i<=n; i++ ) { ② ; ③ ; printf(\; } } 【3.32】下面的函数实现N层嵌套平方根的计算。 double y(double x, int n) { if( n==0 ) return(0); else return ( sqrt(x+( ① )) ); } 【3.33】函数revstr(s)将字符串s置逆,如输入的实参s为字符串\, 则返回时 s 为字符串\。递归程序如下: revstr( char *s ) { char *p=s, c; while(*p) p++; ① ; if(s revstr(s+1); ③ ; } } 如下是由非递归实现的revstr(s)函数: revstr (s) char *s; { char *p=s, c; while( *p ) p++; ④ ; while( s 【3.34】下面函数用递归调用的方法,将str中存放的长度为n的字符串反转过来,例如原来是\,反序为\。 void invent(char *str,int n) { char t; t=*str; *str=*(str+n-1); *(str+n-1)=t; if( n>2 ) invent ( ① ,n-2); else ② ; } 【3.35】从键盘上输入10个整数,程序按降序完成从大到小的排序。 #include sort( int *p, int *q ) { int *max, *s; if( ① ) return; max=p; for( s=p+1; s<=q; s++) if( *s > *max ) ② ; swap( ③ ); sort( ④ ); } swap( int *x, int *y ) { int temp; temp=*x; *x=*y; *y=temp; } main() { int i; printf(\; for( i=0; i<10;i++) scanf(\; sort( ⑤ ); printf(\; for( i=0; i<10; i++) printf(\; } 【3.36】下面函数的功能是将一个整数存放到一个数组中。存放时按逆序存放。例如:483存放成\。 #include void convert(char *a, int n) { int i; if((i=n/10) !=0 ) convert( ① , i ); *a = ② ; } char str[10]= \;
正在阅读:
C语言程序设计填空题及答案复习用12-26
心跳骤停生命支持设备操作10-16
JS-600型酒精回收塔验证方案09-01
春之窗作文400字07-12
Citrix3.0安装配置指南 - 图文12-24
承德外八庙02-19
无领导小组讨论题二 - 资源排序型11-30
17.2--光的粒子性-精品教案04-12
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 习用
- 填空
- 程序设计
- 答案
- 语言
- 沪教版数学二年级下册第二周练习
- 车展总结
- 《数据结构》四川大学 期终复习试题+答案
- 《教育法规概论》课件转出整理-胡明(精品)
- 软件测试报告模板
- 七年级语文上册教案合集2
- 2011年电气分公司立功竞赛总结
- 漫画专题训练 - 图文
- 智能化方案比选
- 挖泥船、拖轮、舰艇、小艇海上运输注意事项
- 全市教育信息化工作会议讲话稿-精选模板
- 2015年度珠海水务集团有限公司销售收入与资产数据报告 - 图文
- 涡阳县第三中学2018-2019学年上学期高二期中化学模拟题
- 积极开展学生社团活动 努力提升学生综合素质1
- 全等三角形的三套测试卷及答案
- 高职教育中的PLC原理与实践-精选文档
- 装饰装修工程完整投标文件
- 班级五项评比评分细则
- 死亡注销城乡养老保险办事具体流程
- 铁塔组立施工作业指导书