原题:海滩上有一堆桃子, 五只猴子来分。 第一只猴子把这堆桃子凭据分为五份, 多了一个,这只猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份, 又多了一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,问海滩上原来最少有多少个桃子?
static void Main(string[] args)
{
int monkey = 1;// 要分桃的次数,就是到第几个猴子分桃了
int allot= 1;//每次分桃的总数,用来判断是否符合条件
//因为每次分桃后数量会更新,所以必须额外声明一个变量
int count = 1;
while (monkey <= 5)// 循环进行分桃判断
{
/*
怎样才算分桃成功呢,就是要%5后还剩一个,然后来五次
-1后才能分平均五份,不就代表着模5要等于1
*/
if (allot% 5 == 1)
{
/*
每次分完后,就剩下原数量的 - 1后的五分之四了,
所以每次要将这个数更新一下
allot / 5 就代表现在的每份桃子的数量
拿掉一份后,就是只剩下四份,所以才乘以4
有人问多一个桃子怎么不-1呢,因为程序/5会直接减掉余数,
所以不用-1后再除。
*/
allot = (allot/ 5) * 4;
monkey++;// 分桃成功的话,就将循环条件变量monkey进行更新
}
else {
/*
如果数值没有判断成功,就代表数值不符合要求,
就要继续找下一个数,说明那个数字不能达到五次的要求,
所以重新再来
*/
// 为了避免allot在if代码块里变化过,所以额外的一个变量来做更新
count++;
// 然后allot重新被赋值,这样allot就算判断失败了,也不会受影响
allot= count;
// 为了避免循环条件变量也被更新过,所以只要有一次判断不成功就重新来过,
//重新设为初始值
monkey = 1;
}
}
Console.WriteLine(count);
}