C 练习实例80
题目:海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子平均分为五份,多了一个,这只 猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了 一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的, 问海滩上原来最少有多少个桃子?
程序分析:无。
程序源代码:
实例
// Created by www.runoob.com on 15/11/9.
// Copyright © 2015年 菜鸟教程. All rights reserved.
//
#include <stdio.h>
int main() {
int n = 0; // n 表示初始桃子数
int i, count;
int found = 0;
while (!found) {
n += 1; // 假设初始桃子数
count = n;
for (i = 0; i < 5; i++) {
if ((count - 1) % 5 == 0) {
count = (count - 1) / 5 * 4;
} else {
break;
}
}
if (i == 5) {
found = 1;
}
}
printf("最少有 %d 个桃子。\n", n);
return 0;
}
以上实例运行输出结果为:
3121
zhapu
zha***163.com.cn
参考方法:
zhapu
zha***163.com.cn
公子小乔
257***[email protected]
设最少有 x 个桃子:
从 e 反推到 x 必须是一个连续的过程,如果中间有间断,就必须返回 e+1 重新计算。
公子小乔
257***[email protected]