C语言(百钱买百鸡的问题)

来自:    更新日期:早些时候
C语言 百钱买百鸡~

#include
void main()
{
int a,b,c;
for(a=0;a<20;a++) //公鸡可能的只数
for(b=0;b<(100-5*a)/3;b++) //母鸡可能的只数
{ c=100-a-b; //总数为100时,小鸡的只数
if(c%3==0 && a*5+b*3+c/3==100) //若小鸡只数是3的倍数,且总价为100
printf("a=%db=%dc=%d
",a,b,c);
}
getch();
return 0;
}

#include
void main()
{
int mj,gj,xj,n=0;
printf(" 百元买百鸡问题求解方案
") ;
printf(" ----------------------
") ;
printf("母鸡公鸡小鸡
") ;
for(mj=0;mj<=100;mj++)
for(gj=0;gj<=100;gj++)
{
xj=100-mj-gj;
if(xj*0.5+mj*3+gj*2==100)
{
n++;
printf("方案%d:%d%d%d
",n,mj,gj,xj);
}
}
}

这段代码中小鸡价值半钱,母鸡价值3钱,公鸡价值2钱,允许某种鸡只数为零
如果和你的题目不同的话,对代码略作修改即可

百钱百鸡问题中国古代数学家张丘建在他的《算经》中提出了著名的“百钱买百鸡问题”:鸡翁一,值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡,问翁、母、雏各几何?
*题目分析与算法设计设鸡翁、鸡母、鸡雏的个数分别为cocks(x),hens(y),chicks(z),题意给定共100钱要买百鸡,若全买公鸡最多买20只,显然cocks的值在0~20之间;
同理,hens的取值范围在0~33之间,可得到下面的不定方程: 5x+3y+z/3=100 x+y+z=100 所以此问题可归结为求这个不定方程的整数解。由程序设计实现不定方程的求解与手工计算不同。在分析确定方程中未知数变化范围的前提下,可通过对未知数可变范围的穷举,验证方程在什么情况下成立,从而得到相应的解。
程序解释
main()

{
int cocks=0,hens,chicks;
while (cocks<=19) //公鸡只数小于19
{hens=0;
while(hens<=33) //母鸡小于33只
{chicks=100-cocks-hens;
if (5.0*cocks+3.0*hens+chicks/3.0==100.0)
printf("%d %d %d\n",cocks,hens,chicks);
hens++;
}
cocks++;
}
}

*总是的进一步讨论这类求解不定方程总理的实现,各层循环的控制变量直接与方程未知数有关,且采用对未知数的取值范上穷举和组合的方法来复盖可能得到的全部各组解。能否根据题意更合理的设置循环控制条件来减少这种穷举和组合的次数,提高程序的执行效率,请读者考虑

设公鸡、母鸡、鸡雏的个数分别为x,y,z,题意给定共100钱要买百鸡,若全买公鸡最多买20只,显然x的值在0~20之间;同理,y的取值范围在0~33之间,可得到下面的不定方程:
5x+3y+z/3=100
x+y+z=100
首先你的外层循环是公鸡的个数,内层循环是母鸡的个数,然后循环有外层开始,公鸡的个数先从0开始,判断公鸡的个数是否小于等于19,若满足则进入内层循环,否则就退出循环,0是小于等于19的,然后给母鸡的个数的初值设为0接着判断0是否小于等于33,若小于等于则进入循环体,否则就退出,0是小于等于33的故就接着往下运行,z=100-x-y;接着判断5*x+3*y+z/3==100吗,若等于则输出然后母鸡的个数加上1,继续判断循环体中的条件是否满足,直到母鸡的个数大于33为止,跳出内层循环,公鸡的个数加1,继续判断条件是否满足;直到公鸡的个数大于19为止,程序结束;
我的解答是否满足你的要求呢

#include"stdio.h"
main()
{
int x,y,z;
for (x=0;x<=100;x++)
 for (y=0;y<=100;y++)
 {
 z=100-x-y;
 if((5*x+3*y+z/3==100)&&(z%3==0))
  printf("母鸡%d公鸡%d小鸡%d
",x,y,z);
 }
}



中国古代数学家张丘建在他的《算经》中提出了著名的“百钱买百鸡问题”:鸡翁一,值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡,问翁、母、雏各几何?

*问题分析与算法设计
设鸡翁、鸡母、鸡雏的个数分别为x,y,z,题意给定共100钱要买百鸡,若全买公鸡最多买20只,显然x的值在0~20之间;同理,y的取值范围在0~33之间,可得到下面的不定方程:
5x+3y+z/3=100
x+y+z=100
所以此问题可归结为求这个不定方程的整数解。
由程序设计实现不定方程的求解与手工计算不同。在分析确定方程中未知数变化范围的前提下,可通过对未知数可变范围的穷举,验证方程在什么情况下成立,从而得到相应的解。

*程序说明与注释
#include<stdio.h>
int main()
{
int x,y,z,j=0;
printf("Folleing are possible plans to buy 100 fowls with 100 Yuan.\n");
for(x=0;x<=20;x++) /*外层循环控制鸡翁数*/
for(y=0;y<=33;y++) /*内层循环控制鸡母数y在0~33变化*/
{
z=100-x-y; /*内外层循环控制下,鸡雏数z的值受x,y的值的制约*/
if(z%3==0&&5*x+3*y+z/3==100)
/*验证取z值的合理性及得到一组解的合理性*/
printf("%2d:cock=%2d hen=%2d chicken=%2d\n",++j,x,y,z);
}
}

*运行结果
Follwing are possible plans to buy 100 fowls with 100 Yuan.
1:cock=0 hen=25 chicken=75
2:cock=4 hen=18 chicken=78
3:cock=8 hen=11 chicken=81
4:cock=12 hen=4 chicken=84

汗...不会吧..很好懂的呀.简单的三元一次方程罢了:

中国古代数学家张丘建在他的《算经》中提出了著名的“百钱买百鸡问题”:鸡翁一,值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡,问翁、母、雏各几何?

解释:就是你手上有一百钱,让你买一百只鸡回来,要你列出所以有的可能性.
假设买X只公鸡 一只公鸡:5钱(也就是你花5个铜钱只能买一个只鸡公)
Y只母鸡 一只母鸡:3钱
Z只小鸡 3只小鸡: 1钱
方程: 5X+3Y+Z/3=100
然后后穷举法,求出所以可能未知数的值.


C语言(百钱买百鸡的问题)视频

相关评论:
  • 17786012305C语言 百钱买百鸡
    居水蒲include<stdio.h> void main(){ int a,b,c;for(a=0;a<20;a++) \/\/公鸡可能的只数 for(b=0;b<(100-5*a)\/3;b++) \/\/母鸡可能的只数 { c=100-a-b; \/\/总数为100时,小鸡的只数 if(c%3==0 && a*5+b*3+c\/3==100) \/\/若小鸡只数是3的倍数,且总价为10...

  • 17786012305c语言程序设计答案 100元买100只鸡,公鸡5元一只,母鸡3元一只,小鸡1元3...
    居水蒲{count ++;printf ("方案%d:%d只公鸡,%d只母鸡,%d只小鸡。\\n",count,i,j,k*3);printf ("100只鸡 = %d + %d + %d\\n",i,j,k*3);printf ("100元钱 = %d×5 + %d×3 + %d\/3 = %d + %d + %d\\n",i,j,k*3,i*5,j*3,k);printf ("\\n"); }}运行结果 ...

  • 17786012305...百钱买鸡:鸡翁一钱值五,鸡母一值钱三鸡雏三值钱一。百钱买百鸡...
    居水蒲include <stdio.h> define money number1 \/ 5 + number2 * 3 + number3 \/ 3 void main(){ int number1; \/\/鸡翁的数目 int number2; \/\/母鸡的数目 int number3; \/\/鸡雏的数目 int sumnumber;for(number1 = 0 ; number1 <= 100 ; number1 += 5)for(number2 = 0; number2 <...

  • 17786012305百钱百鸡问题!!!谢谢
    居水蒲include <stdio.h> void main(){ int j,i,k,n,m,l;printf("请输入你花了多少钱,买了多少只鸡:");scanf("%d %d",&j,&k);for(i=1;i<=k;i++){ for(n=1;n<=k;n++){ for(m=3;m<=k;m+=3){ if(i*5+n*3+m\/3==j)printf("公鸡买了%d,母鸡买了%d,小鸡鸡买了...

  • 17786012305C语言编写程序解决百钱白鸡问题
    居水蒲按照题目要求编写的解决百钱买百鸡问题的C语言程序如下 include<stdio.h>int main(){ int a,b,c; for (a = 0; a <= 20; a++) for (b = 0; b <= 33; b++) { c = 100 - a - b; if (c%3==0 && 5*a + 3*b +c\/3 == 100) printf("鸡翁%d只,鸡母...

  • 17786012305百元买百鸡,公鸡5元,母鸡3元,小鸡2只1元.c语言编程,求解,给跪了_百度...
    居水蒲思路:三个循环,将每种情况都按最大化考虑;判断条件是:既要求所有钱为100元并且所有数也是100个。include <stdio.h> main(){ int x,y,z;for(x=0;x<=20;x++)for(y=0;y<=33;y++)for(z=0;z<=200;z++)if((x*5+y*3+(int)(z*0.5)==100)&&(x+y+z==100))printf("x=...

  • 17786012305c 语言百钱买百鸡 一次 循环 解决 求思路
    居水蒲include <stdlib.h> include <stdio.h> int main(){ int a,b,c,num,mon,i;\/\/a,b分别为公鸡母鸡数量,c为雏鸡数量除以3 printf("本程序用来解决百钱买百鸡的问题。\\n");system("pause");for(c=0;c<=33;c++){ num=100-3*c;mon=100-c;if((mon-3*num)%2==0){ a=(mon-3*...

  • 17786012305百元买百鸡 公鸡2元 母鸡1.5元 小鸡0.5元用C语言怎么写
    居水蒲include<stdio.h> main(){ int x,y,z,cnt=0;printf("百钱百鸡可能的解决方案:\\n");for(x=0;x<=50;x++)for(y=0;y<=66;y++){ z=100-x-y;if((z%2==0)&&2*x+1.5*y+z\/2==100){ cnt++;printf("解决方案%d:公鸡: %2d 母鸡: %2d 小鸡:%2d\\n",cnt,x,y,...

  • 17786012305用c#求百鸡百钱,100元买100只鸡,公鸡5元1只,母鸡3元1只,小鸡1元3只...
    居水蒲int cock = 0; \/\/公鸡的数量 公鸡5元一只 int hen = 0; \/\/母鸡的数量母鸡3元一只 int chick = 0; \/\/小鸡的数量小鸡1元三只 int index = 1;for (cock = 0; cock <= 33; cock++) \/\/100块最多买33只公鸡 { for (hen = 0; hen <= 20; hen++)\/\/100块最多买20...

  • 17786012305百钱买百鸡问题。公鸡每只5元,母鸡每只3元,小鸡3只一元,问一百元买一...
    居水蒲x[t]=c;t++;} k=t;} main()...{ int n;int gongji[50],muji[50],xiaoji[50],num=0;int i,*p_num=#printf(\\"公鸡5元每只,母鸡3元每只,小鸡3只1元 \\");printf(\\"n元买n只鸡,请输入n的值:\\");scanf(\\"%d\\",&n);chicken_question(n,p_num,gongji,muji,xiaoji)...

  • 相关主题精彩

    版权声明:本网站为非赢利性站点,内容来自于网络投稿和网络,若有相关事宜,请联系管理员

    Copyright © 喜物网