《用穷举法设计程序》习题精讲_第1页
《用穷举法设计程序》习题精讲_第2页
《用穷举法设计程序》习题精讲_第3页
《用穷举法设计程序》习题精讲_第4页
《用穷举法设计程序》习题精讲_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

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

文档简介

《用穷举法设计程序》

习题精讲问题1:从1~10中找出所有是3倍数的数。用流程图描述解决此数学问题的算法。输出i开始i←1i≤10i←i+1结束NYi是3的倍数YN#include<cstdio>usingnamespacestd;intmain(){inti=1;

while(i<=10)

{if(i%3==0)printf(“%d\n”,i);i=i+1;

}}问题2:从1~100中找出所有能被7或9整除的数。用流程图描述解决此数学问题的算法。输出i开始i←1i≤100i←i+1结束NYi能被7或9整除YN#include<cstdio>usingnamespacestd;intmain(){inti;for(i=1;i<=100;i=i+1)

{if(i%7==0||i%9==0)printf(“%d\n”,i);}}问题3:打印输出由1、2……8、9这九个数字组成的所有可能的二位数n。用流程图描述。分析:个位数上的数字可以是那几种数字?用变量i来表示。十位数上的数字可以是那几种数字?用变量j来表示。找出二位数n与i、j之间的关系。提示:548=5×100+4×10+8输出n开始j←1j≤9i←i+1结束NNi←1Yi≤9n←j*10+iYj←j+1执行过程:j=1in34567891021111213141516171819j=2#include<cstdio>usingnamespacestd;intmain(){intj,i,n;

j=1;While(j<=9)

{i=1;

While(i<=9)

{

n=j*10+i;printf(“%d”,n);i=i+1;

}j=j+1;

}

}问题4:打印输出由1、2……8、9这九个数字组成的所有可能的二位数n。#include<cstdio>usingnamespacestd;intmain(){inti,j;for(i=1;i<=9;i++){for(j=1;j<=9;j++){printf("%d\n",i*10+j);}}return0;}

标准输入输出速度比较快。流输入输出在数据比较多,比如1000000个数据的时候会很慢。问题5:(四大湖问题)上地理课时,四个学生回答我国四个淡水湖大小时说:

A学生:洞庭湖最大,洪泽湖最小,鄱阳湖第3

B学生:洪泽湖最大,洞庭湖最小,鄱阳湖第2,太湖第3

C学生:洪泽湖最小,洞庭湖第3

D学生:鄱阳湖最大,太湖最小,洪泽湖第2,洞庭第3

对于湖的大小,每个学生仅答对一个,请编程判断四个湖的大小1.分析与算法设计(1)定义变量:

a—洞庭湖,a可能的取值{1,2,3,4}

b—洪泽湖,b可能的取值{1,2,3,4}

c—鄱阳湖,c可能的取值{1,2,3,4}

d—太湖,d可能的取值{1,2,3,4}

a,b,c,d四个变量的取值互不相同,1表示最大,4表示最小(2)用变量表示条件

A学生的叙述可表示为:a==1,b==4,c==3这是三个关系表达式,由于每个学生的叙述只有一个正确,所以这三个关系表达式的值的和应等于1。

A学生的叙述可表示成:

((a==1)+(b==4)+(c==3))==1

同理,B学生的叙述表示成:

((b==1)+(a==4)+(c==2)+(d==3))==1

(2)用变量表示条件

A学生的叙述可表示为:a==1,b==4,c==3这是三个关系表达式,由于每个学生的叙述只有一个正确,所以这三个关系表达式的值的和应等于1。C学生的叙述可表示成:

((b==4)+(a==3))==1D学生的叙述可表示成:

((c==1)+(d==4)+(b==2)+(a==3))==1

for(a=1;a<=4;a++)for(b=1;b<=4;b++)for(c=1;c<=4;c++)for(d=1;d<=4;d++){ca=((a==1)+(b==4)+(c==3))==1; cb=((b==1)+(a==4)+(c==2)+(d==3))==1;cc=((b==4)+(a==3))==1;cd=((c==1)+(d==4)+(b==2)+(a==3))==1;

if(ca&&cb&&cc&&cd){printf("TongTing=%d\n",a);

printf("Hongzhe=%d\n",b); printf("Poyang=%d\n",c);

printf("Taihu=%d\n",d);}}//endfor(3)穷举:穷举a,b,c,d四个变量的所有可能取值,进行测试,满足前述四个条件的取值就是我们所要的结果问题6:输入绳子的长度n,将该绳子分成三段,每段的长度为正整数,输出由该三段绳子组成的三角形个数。

算法分析:

没有公式直接求出三角形的个数,所以程序只能采用穷举法,一一验证范围内的数是否能构成三角形,若是则累计。

温馨提示

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

评论

0/150

提交评论