鸡兔同笼(简易版)
已知鸡和兔的总数量n,总脚数为m,输入n和m,依次输出鸡和兔的数目,如果无解,输出“no answer”
这道题有一定的逻辑性
注意事项:
1.一开始学习的时候尽量让代码对齐,括号对齐。
2.while(scanf("%d %d",&m,&n)!=EOF)意思是输入的两个值不等于EOF就一直循环,EOF意思是-1,但是结束肯定不是输入-1,需要按ctrl+z键退出循环,这是初学c语言实现连续输入的好方法!
解题思路:
1.第一个判断n>m那个判断是考虑到两个数据顺序输反了,交换
2.第二个判断是判断是否数据违规(总不能出现单数的脚把(别杠谢谢),后面那个也得满足,超了就是有变异的鸡或者兔纸)
3.重点!假设全是鸡,就是两倍鸡的腿,用全部的腿m减去两倍鸡的腿2n再乘以0.5就是兔子数量(兔子腿是鸡的俩倍,多余的腿肯定是兔子的,因为全看成两条腿的鸡,所以四条腿的兔子要*0.5转换为鸡的)
#include <stdio.h>
int main()
{
int m,n,a,b,t;
while(scanf("%d %d",&m,&n)!=EOF)
{
if(n>m)
{
t=n;n=m;m=t;
}
if(m%2==0&&m>=2*n&&m<=4*n)
{
b=(m-2*n)*0.5;
a=n-b;
printf("%d %d\n",a,b);
}
if(m<0||n<0||m%2!=0||m<2*n||m>4*n)
printf("no answer\n");
}
return 0;
}
如果题目完全一致,说不定是一个学校的【狗头保命】,可以关注一下,后期发数据结构
第一篇文章的个人感悟:还是想写点文章记录一下自己的学习过程,水平尚低,欢迎斧正!
后面会发一些关于javaweb,mysql,linux,数据结构与算法,渗透测试工程师入门的一些文章,希望可以支持一下。
PS:我在说什么。。。。。。。
更多推荐
C语言入门之鸡兔同笼(简易版)
发布评论