阅读下列函数说明和C代码及流程图,将应填入(n)处的字句写在对应栏内 [说明] 分糖果问题是一个经
阅读下列函数说明和C代码及流程图,将应填入(n)处的字句写在对应栏内
[说明]
分糖果问题是一个经典问题。问题描述如下:幼儿国有n(<20)个孩子围成一圈分糖果,老师先随机地发给每个孩子若干颗糖果,然后按以下规则调整:每个孩子同时将自己手中的糖果分一半给坐在他右边的小朋友;如共有8个孩子,则第1个将原来的一半分给第2个,第2个将原有的一半分给第3个……第8个将原来的一半分给第1个,这样的平分动作同时进行;若平分前,某个孩子手中的糖果是奇数颗,则必须从老师那里要一颗,使他的糖果变成偶数。小孩人数和每个小孩的初始数由键盘输入。经过多少次调整,使每个孩子手中的糖果一样多,调整结束时每个孩子有糖果多少颗,在调整过程中老师又新增发了多少颗糖果。
[C程序]
include <stdlib.h>
include <stdio.h>
bool allequall (int child[], int n ) //判断各小孩子手中的糖果是否相等
{
for ( int i=0; i<n-1; i++)
if (child[i]!=child[i+1] )
return false; //不相等返回假
return true; //相等返回真
}
const int MaxNum=20; //定义最大人数
//主函数
void main ( )
{
int Num=0;
int *child;
int *child1;
//构造两个相应大小的数组child代表小朋友现有的粮果数child1代表小朋友原来有的糖果数
int Tnum=0;
int i=0;
do{
printf ( "Pelase input the number of the children: ").,
scanf ( "%d",&Num );
if ( Num>MaxNum )
printf ( "Error Number!!" );
} while ( Num>MaxNum );
child=new int [Nmn];
child1=new int [Num];
for ( i=0; i<Num; i++ ) //将数组赋值
{
printf ( "Input NO. %d child"s candy numbers: ",i+1);
scanf ( "%d", &child[i] );
}
while ( (1) )
{
for (i=0; i<Num; i++ )
{
if( (2) )
{
(3)
Tnum++;
}
}
for ( i=0; i<Num; i++ )
child1[i]=child[i]; //将child1赋值用来记忆原来小朋友的粮果数
for ( i=0; i<Nam; i++ )
(4)
for (i=0; i<Num-1; i++)//用循环实现前一个小朋友粮果数加后一个小朋友粮果数的一半
{
child[i]/=2;
child[i]+=child 1 [i+1];
}
child[Num-1]/=2;
(5)
}
printf ( "每个同学最后分到糖果数目是%d\n", child[1]);
printf ( "老师分发出的糖果是%d\n", Tnum );
}
图12-7是一种解决问题的流程图,请根据该流程图将对应C代码(n)处补充完整。
(1)!allequall(child, Num) (2)child[i]%2!=0 (3)child[i]++; (4)child1[i]/=2; (5)child[Num-1]+=child1[0] 解析:此题是一个经典文题“分糖果问题”的一种解法。主要考查考生理解问题、阅读流程图及代码的能力。流程图已经很清楚地把程序代码的思路给表达出来了。对于(1)可以看出应该是程序循环的条件,当糖果数不相等时循环。(2)则判断孩子手中的糖果个数是否奇数。(3)则从老师手中额外取得一颗糖果。(4)求出原来每个小朋友糖果数的一半。(5)把最后一个小朋友糖果数的一半加第一个小朋友的糖果数
画出y=|x+1|-|X-1|的图像.说下方法. 数学 2020-04-06 …
3、读北半球中高纬度环流示意图,分析下列说法中正确的是( )3、读北半球中高纬度环流示意图,分析下 其他 2020-05-16 …
读图,完成下列问题。福建省及周边地区武夷山M坡和N坡海拔300米处6月与12月气温对比柱状图(1) 语文 2020-06-17 …
下图是某地由于热力作用而形成的近地面与高空气压值分布雷达图,读图回答下列各题。小题1:下列关于P、 语文 2020-07-20 …
如图所示,将甲图的条形磁铁从中间锯断,如乙图所示,则下列关于乙图的说法中正确的是()。A.a端是N极 物理 2020-11-01 …
从E-R图导出关系模型时,如果两实体间的联系是m:n的,下列说法正确的是()从E-R图导出关系模型时 其他 2020-11-02 …
在边长为4的正方形ABCD上有一点P,沿边BC.CD.DA由B向A运动,设点P运动路程为x,三角形… 数学 2020-11-04 …
如图所示,手用力向下压架在两本书之间的尺子,尺子发生了弹性形变.若手对尺子的压力为N,尺子对手的弹力 物理 2020-11-08 …
下图为M、N两国一定时期内出生率和死亡率曲线图,据图回答下列各题。1.M、N两国属于()A.M发达国 语文 2020-11-11 …
下图是乌鲁木齐(43°47′N)、拉萨(29°40′N)、重庆(29°31′N)和海口(20°02′ 语文 2020-11-13 …