百钱百鸡问题

//中国古代数学家张丘建在他的《算经》中提出了著名的“百钱买百鸡问题”:鸡翁一,值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡,问翁、母、雏各几何?
#include<iostream>
using namespace std;
int main()
{
 int cock,hen,chick;//分别代表雄鸡,母鸡,小鸡的个数
 int cn,hn,ch;//代表某些鸡所花费的钱
 for(cock=0;cock<20;cock++)
 {
  cn=cock*5;
  for(hen=0;hen<33;hen++)
  {
   hn=hen*3;
   for(chick=0;chick<300;chick++)
   {
    ch=1/3;
    if(cock+hen+chick==100)
    {
     cout<<"雄鸡"<<cock<<"只";
     cout<<"母鸡"<<hen<<"只";
     cout<<"小鸡"<<chick<<"只"<<endl;
    }
   }
  }
 }
 return 0;
}
穷举法,不知道名字,以前也有这样的情况,只是想着写出来,不知道具体方法的具体名字,之前用辗转相除做公倍数公约数,结果出来之前还不知道那个方法叫做辗转相除法,怎么说呢,就从字面意思来理解,就是举出所有可行的方法。
还是那样,不用的刀会变钝,不会运用知识还是一把钝刀。



可是还是不出所料,怎么可能那么多的可能,就加了一下价钱根本就不对啊。。。。。。之后改进了还好,我真是弱爆了。


#include<iostream>
using namespace std;
int main()
{
	int cock,hen,chick;
	for(cock=0;cock<=20;cock++)
	{
		for(hen=0;hen<=33;hen++)
		{
			for(chick=0;chick<=300;chick++)
			{
				if(cock+hen+chick==100&&chick%3==0&&cock*5+hen*3+chick/3==100)
				{
					cout<<"雄鸡"<<cock<<"只";
					cout<<"母鸡"<<hen<<"只";
					cout<<"小鸡"<<chick<<"只"<<endl;
				}
			}
		}
	}
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值