早教吧作业答案频道 -->数学-->
泊松趣味数学题某人有12品脱的啤酒,想从中倒出6品脱,可他没有6品脱的容器.只有1个8品脱的容器,和一个5品脱的容器.问怎没使8品脱的容器装满6品脱的啤酒.
题目详情
泊松趣味数学题
某人有12品脱的啤酒,想从中倒出6品脱,可他没有6品脱的容器.只有1个8品脱的容器,和一个5品脱的容器.问怎没使8品脱的容器装满6品脱的啤酒.
某人有12品脱的啤酒,想从中倒出6品脱,可他没有6品脱的容器.只有1个8品脱的容器,和一个5品脱的容器.问怎没使8品脱的容器装满6品脱的啤酒.
▼优质解答
答案和解析
问题分析与算法设计
将12品脱酒 8品脱和5品脱的空瓶平分,可以抽象为解不定方程:
8x-5y=6
其意义是:从12品脱的瓶中向8品脱的瓶中倒x次,并且将5品脱瓶中的酒向12品脱的瓶中倒y次,最后在12品脱的瓶中剩余6品脱的酒.
用a,b,c代表12品脱、8品脱和5品脱的瓶子,求出不定方程的整数解,按照不定方程的意义则倒法为:
a -> b -> c ->a
x y
倒酒的规则如下:
1) 按a -> b -> c ->a的顺序;
2) b倒空后才能从a中取
3) c装满后才能向a中倒
按以上规则可以编写出程序如下:
*程序说明与注释
#include
void getti(int a,int y,int z);
int i; /*最后需要分出的重量*/
int main()
{
int a,y,z;
printf("input Full a,Empty b,c,Get i:"); /*a 满瓶的容量 y:第一个空瓶的容量 z:第二个空瓶的容量*/
scanf("%d%d%d%d",&a,&y,&z,&i);
getti(a,y,z); /*按a -> y -> z -> a的操作步骤*/
getti(a,z,y); /*按a -> z -> y -> a的步骤*/
}
void getti(int a,int y,int z) /*a:满瓶的容量 y:第一个空瓶的容量 z:第二个空瓶的容量*/
{
int b=0,c=0; /* b:第一瓶实际的重量 c:第二瓶实际的重量*/
printf(" a%d b%d c%d\n %4d%4d%4d\n",a,y,z,a,b,c);
while(a!=i||b!=i&&c!=i) /*当满瓶!=i或另两瓶都!=i*/
{
if(!b)
{ a-=y; b=y;} /*如果第一瓶为空,则将满瓶倒入第一瓶中*/
else if(c==z)
{ a+=z; c=0;} /*如果第二瓶满,则将第二瓶倒入满瓶中*/
else if(b>z-c) /*如果第一瓶的重量>第二瓶的剩余空间*/
{ b-=(z-c);c=z;} /*则将装满第二瓶,第一瓶中保留剩余部分*/
else{ c+=b; b=0;} /*否则,将第一瓶全部倒入第二瓶中*/
printf(" %4d %4d %4d\n",a,b,c);
将12品脱酒 8品脱和5品脱的空瓶平分,可以抽象为解不定方程:
8x-5y=6
其意义是:从12品脱的瓶中向8品脱的瓶中倒x次,并且将5品脱瓶中的酒向12品脱的瓶中倒y次,最后在12品脱的瓶中剩余6品脱的酒.
用a,b,c代表12品脱、8品脱和5品脱的瓶子,求出不定方程的整数解,按照不定方程的意义则倒法为:
a -> b -> c ->a
x y
倒酒的规则如下:
1) 按a -> b -> c ->a的顺序;
2) b倒空后才能从a中取
3) c装满后才能向a中倒
按以上规则可以编写出程序如下:
*程序说明与注释
#include
void getti(int a,int y,int z);
int i; /*最后需要分出的重量*/
int main()
{
int a,y,z;
printf("input Full a,Empty b,c,Get i:"); /*a 满瓶的容量 y:第一个空瓶的容量 z:第二个空瓶的容量*/
scanf("%d%d%d%d",&a,&y,&z,&i);
getti(a,y,z); /*按a -> y -> z -> a的操作步骤*/
getti(a,z,y); /*按a -> z -> y -> a的步骤*/
}
void getti(int a,int y,int z) /*a:满瓶的容量 y:第一个空瓶的容量 z:第二个空瓶的容量*/
{
int b=0,c=0; /* b:第一瓶实际的重量 c:第二瓶实际的重量*/
printf(" a%d b%d c%d\n %4d%4d%4d\n",a,y,z,a,b,c);
while(a!=i||b!=i&&c!=i) /*当满瓶!=i或另两瓶都!=i*/
{
if(!b)
{ a-=y; b=y;} /*如果第一瓶为空,则将满瓶倒入第一瓶中*/
else if(c==z)
{ a+=z; c=0;} /*如果第二瓶满,则将第二瓶倒入满瓶中*/
else if(b>z-c) /*如果第一瓶的重量>第二瓶的剩余空间*/
{ b-=(z-c);c=z;} /*则将装满第二瓶,第一瓶中保留剩余部分*/
else{ c+=b; b=0;} /*否则,将第一瓶全部倒入第二瓶中*/
printf(" %4d %4d %4d\n",a,b,c);
看了泊松趣味数学题某人有12品脱的...的网友还看了以下:
某人有12品脱(英容量单位,1品脱=0.568升)啤酒一瓶,想从中倒出6品脱,但他没有6品脱的容器 2020-04-07 …
某人有12升啤酒一桶,想从中倒出6升.但是他没有6升的容器,只有一个8升的容器和一个5升的容器.怎 2020-04-27 …
某人有12升啤酒一瓶,想从中倒出6升.但没有6升的容器,只有一个8升的容器和一个5升的容器.怎样的 2020-06-15 …
某人有12品脱啤酒一瓶(品脱是英容量单位,1品脱=0.568升),想从中倒出6品脱.但是他没有6品 2020-06-20 …
一个容器内装有12升纯酒精,倒出3升后,用水加满,再倒出6升,再用水加满,然后倒出9升,再用水加满 2020-06-21 …
某人有一瓶12升的啤酒,想从中倒出6升啤酒,但是他没有6升的容器,只有一个8升的容器和一个5升的容 2020-07-08 …
一瓶纯酒精第1次倒出6升补满水后第2次又倒出6升还剩下的是纯3升的溶液,问该瓶纯酒 2020-11-08 …
英语翻译1他把杯子里的水全部倒掉了.2他把被子里的水倒掉了三分之一/一半.3我要发个传真,请您给个信 2020-12-12 …
过年的时候,康康给客人倒啤酒,一瓶啤酒可以倒满4杯,球球倒酒的时候总是每杯中有半杯泡沫,啤酒倒成泡沫 2020-12-12 …
泊松趣味数学题某人有12品脱的啤酒,想从中倒出6品脱,可他没有6品脱的容器.只有1个8品脱的容器,和 2020-12-13 …