C++第11周项目2(3)参考——年龄几何

本文通过一个具体的实例——年龄几何问题,介绍了如何使用穷举法(枚举法)来寻找符合特定条件的等差数列。文章提供了一段C++代码实现,并展示了运行结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565


【项目2:穷举法解决组合问题】先阅读例题,领会穷举法(意为“穷尽式列举”,也称枚举)的思想,然后自行选题进行解决,掌握这种程序设计的一般方法。

任务:利用穷举的方法解决下面的问题(选做一道即算完成任务,其他可以抽时间自由安排,多做会使你更聪明。)


3)年龄几何:张三、李四、王五、刘六的年龄成一等差数列,他们四人的年龄相加是26,相乘是880,求以他们的年龄为前4项的等差数列的前20项。

提示:设数列的首项为n,公差为a,则前4项之和为"4*n+6*a",项之积为"n*(n+a)*(n+a+a)*(n+a+a+a)"。同时"1<=a<=4","1<=n<=6"。可采用穷举法求出此数列。

#include<iostream>  
using namespace std;  
int main()  
{  
    int a,n,i,s;  
    for(a=1;a<=4;a++)  //枚举
        for(n=1;n<=6;n++)  
			if(n*4+a*6==26 && n*(n+a)*(n+a+a)*(n+a+a+a)==880)  
			{
				cout<<n;  //输出第1个
				for(i=1;i<20;i++)  
				{  
					s=n+a*i;  
					cout<<","<<s;  //后面的19个都和前一个用逗号分隔输出
				}  
				cout<<endl;  
			}
	return 0;  
}  

运行结果:


评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迂者-贺利坚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值