- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验2循环结构
实验
2?
?
循环结构
?
程序填空
?
1.
??
本题分值:
10?
题目描述:
马克思曾经出过这样一道趣味数学题:有
30
个人在一家小饭馆里用餐,其中有男人、女人和小
孩。每个男人花了
3
先今,每个女人花了
2
先令,每个小孩花了
1
先令,一共花去
50
先令。问男人、女人
以及小孩各有几个人。以下是完成此项工作的程序,请将未完成的部分填入,实现其功能,并在计算机上
调试程序,以测试填入的部分是否正确。
?
代码:
?
#includeiostream?
using?namespace?std;?
int?main()?
{?
????int?n;????//n
记录解的个数
?
????int?a,b,c;??//
分别记录男、女、小孩的人数
?
????n=__(1)__;????//
初始化
n
的值
?
????for(a=1;a=30;a++)?
????{?
????????for(b=1;b=30;b++)?
????????{?
????????????c=__(2)__;?
????????????if(?__(3)__?)?
????????????{?
????????????????cout
男人有
:a
个;
女人有:
b
个;
小孩有:
c
个。
endl;?
????????????????n++;?
????????????}?
????????}?
????}?
????cout
共有
n
种方案
endl;?
????return?0;?
}?
?
2.
??
本题分值:
10?
题目描述:
下面程序的功能是输出
1
至
100
之间每位数的乘积大于每位数的和的数,请填空使程序完整,
并在计算机上调试程序,以测试填入的部分是否正确。
?
代码:
?
#include?iostream?
using?namespace?std;?
int?main()?
{?
????int?n,?k=1,?s=0,?m??
????for?(n=1??n=100??n++)?
????{?
????????k=1??s=0??
????????__(1)__;?
????????while?(?__(2)__?)?
????????{?
????????????k*=m%10;?
????????????s+=m%10;?
????????????__(3)__;?
????????}?
????????if?(ks)??coutn?;?
????}?
????return?0;?
}
3.题目描述:
一个数如果恰好等于除它本身的所有因子之和,这个数就称为完数。例如,6=1+2+3,?6就称为完数。输出1000以内所有满足完数条件的数及其个数。请阅读以下不完整的程序,并在计算机上调试该程序以补足其中的空格,实现其功能。
?代码:
?#includeiostream?
using?namespace?std;?
int?main()?
{?
? int?n,s,i,count=0;?
? cout1000以内的完数为:;?
? for(n=1;n1000;n++)?
{?
? s=0;?
? for(i=1;in;i++)?//计算小于n的因数和
? if?(n%i==0)??s=s+i;??//如果i是n的因数
if?(s==n)?//判断是否满足完数的条件
{?
? coutn?;?
count=count+1;?//完数的个数+1?
? }?
? }?
?coutendl1000以内完数的个数为:countendl;?
?return?0;?
}?
?
4.
?
题目描述:
求100以内能被3整除且个位数字为9的所有正整数。请阅读以下不完整的程序,并在计算机上调试该程序以补足其中的空格,实现其功能。
?
代码:
?#includeiostream?
using?namespace?std;?
int?main()?
{?
? int?i;?
? for(i=1;i100;i++)?
? {?
? if(i%3==0?i%10==9)?
? couti?;?
}?
?return?0;?
}?
5.
?
题目描述:
求输入的两个正整数的最大公约数。请阅读以下不完整的程序,并在计算机上调试该程序以补足其中的空格,实现其功能。
?代码:
#includeiostream?
using?namespace?std;?
int?main()?
{?
? int?x,m,n;?
? cinmn;?
? if(mn)?x=m;?
? else?x=n;?//x取m和n
文档评论(0)