C语言实验10(附参考答案).doc_第1页
C语言实验10(附参考答案).doc_第2页
C语言实验10(附参考答案).doc_第3页
C语言实验10(附参考答案).doc_第4页
C语言实验10(附参考答案).doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

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

文档简介

实验10:循环结构(1)实验目的:(1)领会程序设计中构成循环的三要素;(2)熟练掌握用while语句实现循环的方法。(3)熟练掌握用do-while语句实现循环的方法。实验内容:1、C语言中,while与dowhile循环的主要区别是_。A)dowhile的循环体至少无条件执行一次B)while的循环控制条件比dowhile的循环控制条件严格C)dowhile允许从外部转到循环体内D)dowhile的循环体不能是复合语句2、设有程序段int k=10;while(k) k=k-1;则下面描述中正确的是( )。A)while循环执行10次B)循环是无限循环C)循环体语句一次也不执行D)循环体语句执行一次3、下述程序段的运行结果是_。int a=1,b=2,c=3,t;while (abc) t=a; a=b; b=t; c-;printf(“%d,%d,%d”,a,b,c); A)1,2,0 B)2,1,0 C)1,2,1 D)2,1,14、下面程序的功能是用do-while语句求1至1000之间满足“用3除余2;用5除余3;用7除余2”的数,且一行只打印五个数。请填空。#include main()int i=1,j=0;doif( i%3=2&i%5=3&i%7=2 )printf(“%4d”,i);j=j+1;if( j%5=0 ) printf(“n”);i=i+1;while(i1000);5、下面程序的功能是将从键盘输入的一组字符中统计出大写字母的个数m和小写字母的个数n,并输出m、n中的较大者,请选择填空。#include main()int m=0,n=0;char c;while( )!=n) if(c=A&c=a&c=z) n+;printf(“%dn”,mn? );(1) A)c=getchar()B)getchar()C)scanf(“%c”,c)(2) A)n:mB)m:nC)m:mD)n:n程序设计题1、(必做题)求出以下表达式的值。S1=1+1/2+1/3+1/4 +1/100;S2=1-1/3+1/5-1/7+-1/99;#includevoid main()double i,a=1;double s1=0,s2=0;for(i=1;i=100;i+)s1+=1/i;for(i=1;i99;i+=2)s2=s2+a/i;a=-a;printf(1+1/2+1/3 +1/100=%lfn1-1/3+1/5-1/99=%lfn,s1,s2);2、(必做题)输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。【程序分析】提示:利用while语句,条件为输入的字符不为n.#includevoid main()char ch;int character=0,space=0,numbers=0,others=0;printf(请输入一行字符:n);while(ch=getchar()!=n)if(ch=A&ch=a&ch=0&ch=9) numbers+;else others+;printf(字母有%d个,空格有%d个,数字有%d个,其他字符有%d个n,character,space,numbers,others);3、(必做题)求S=10!#includevoid main()int i=1,jiecheng=1;while(i=10)jiecheng=jiecheng*i;i+;printf(10!=%dn,jiecheng);4、(选做题)从键盘上输入若干正整数,求其中最大数和最小数。输入的数以0结束【程序分析提示】 (1)设第一个读取的数是当前最大数和最小数; (2)若当前读取的整数不为0,则继续循环; (3)若当前读取的数比最大数大,则记录为最大数;比最小数小,则记录为最小数; (4)读取下一个整数。#includevoid main()int number,max,min;printf(请输入若干正整数,输入0表示结束:n);scanf(%d,&number);max=min=number;while(number!=0)if(maxnumber) max=number;if(minnumber) min=number;scanf(%d,&number);printf(max=%d,min=%dn,max,min);5、(选做题)求解爱因斯坦数学题。有一条长阶梯,若每步跨2阶,则最后剩余1阶,若每步跨3阶,则最后剩2阶,若每步跨5阶,则最后剩4阶,若每步跨6阶则最后剩5阶,若每步跨7阶,最后才正好一阶不剩。请问,这条阶梯共有多少阶? 分析:据题意,阶梯数满足下面一组同余式:x mod 2=1x mod 3=2x mod 5=4x mod 6=5x mod 7=0#includevoid main()int x=1;while(1)if(x%2=1&x%3=2&x%5=4&x%6=5&x%7=0)printf(该数字为%d.n,x);break;x+;6、(选做题)从键盘任意输入两个整数,输出他们的最大公约数和最小公倍数,可用“辗转想除法”,或者可完成下列程序填空。#in

温馨提示

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

评论

0/150

提交评论