您的位置:首页 > 其它

ex2_1 鸡兔同笼问题

2013-11-20 17:54 155 查看

问题描述

一个笼子里面关了鸡和兔子(鸡有2 只脚,兔子有4 只脚,没有例外)。已经知道了笼子里面脚的总数a,问笼子里面至少有多少只动物,至多有多少只动物?

思考过程

呃,这个问题思考的时候我居然首先是想用枚举法。想用for循环从1开始,然后列举出所有的鸡兔数量的可能性。但后来发现,自己一个兔子不是就是相当于两只鸡吗?于是就发现其实不用一一枚举计算,题目中只是要求最多或最少的动物,并没有其他条件,直接简单的除法加判断就能完成。

#include<iostream>
using namespace std;
int main()
{
int FeetNum;			//腿的总数量
while(cin >> FeetNum){
if(FeetNum % 2 != 0)
cout << "0 0" << endl;
else{
cout << FeetNum / 2 << " ";
if(FeetNum % 4 == 0)
cout << FeetNum / 4 << endl;
else
cout << FeetNum / 4 + 1 << endl;
}
}
return 0;
}


这个鸡兔同笼问题,让我想到了小学的时候做的鸡兔同笼问题,在该问题上,将腿总数给出的同时,也将头的总数给出了,这样就可以确定鸡和兔分别的数量。这个问题好像叫和差问题。
#include<iostream>
using namespace std;

#define tuzi 4					//兔子的腿数
#define ji 2					//鸡的腿数

int main()
{
int FeetNum,HeadNum;			//总腿数,总头数
while(cin >> FeetNum && cin >> HeadNum){
if(FeetNum % 2 != 0)
cout << "腿数错误!" << endl;
else if(HeadNum * tuzi < FeetNum || HeadNum * ji > FeetNum)
cout << "头数错误!" << endl;
else{
int LastFeet,tuziHead;		//剩余腿数,兔子头数
LastFeet = FeetNum - ji * HeadNum;
if(LastFeet){
tuziHead = LastFeet / (tuzi - ji);
cout << "兔子:" << tuziHead << " 鸡:" << HeadNum - tuziHead << endl;
}else{
cout << "兔子:0 鸡:" << HeadNum << endl;
}
}
}
return 0;
}


好像韩信点兵也是和差问题,我再查查看看
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: