海滩上有一堆桃子,五只猴子来分。 第一只猴子把这堆桃子平均分为五份,多了一个, 这只猴子把多的一个扔入海中,拿走了一份。 * 第二只猴子把剩下的桃子又平均分成五份,又多了一个, 它同样把多的一个扔入海中,拿走了一份, 第三、第四、第五只猴子都是这样做的, * 问海滩上原来最少有多少个桃子?


题目:海滩上有一堆桃子,五只猴子来分。 第一只猴子把这堆桃子平均分为五份,多了一个, 这只猴子把多的一个扔入海中,拿走了一份。
* 第二只猴子把剩下的桃子又平均分成五份,又多了一个, 它同样把多的一个扔入海中,拿走了一份, 第三、第四、第五只猴子都是这样做的,
* 问海滩上原来最少有多少个桃子?

 

思路1: 逆序 原来 第1只 第2只 第3只 第4只 第5只 n n-n/5-1 m-m/5-1 x-x/5-1 使用递归来解决问题

 

public class 第四十一题猴子分桃子 { public static void main(String[] args) { /* * 思路: 逆序 原来 第1只 第2只 第3只 第4只 第5只 n n-n/5-1 m-m/5-1 x-x/5-1 使用递归来解决问题 */
        int sum = 0; for (int i = 60; i < 6100; i++) { int n = i; for (int m = 1; m < 6; m++) { sum += getValue(n, m); } if (sum == n) { System.out.println(i); } } } // 获取第m只猴子拿走的桃数量
    public static double getValue(int d, int m) {// n为总数,m为第1,2,3,4,5只猴
        int result = 0; // 保存结果
         result =  d / 5 + 1; // 第一只
        if (m == 1) { return result; } else { return getValue((d - result), m - 1); } } }

 

思路2: 

设第5只猴子得到a个桃子.分队前有5a+1 第四只得到 (5a+1)/4 分堆前有 (5a+1)/4 + 1 .我想知道为什么 第四子猴子得到
* (5a+1)/4 为什么不是 (5a+1)/5 为什么第四子得到的不是 5a+1
*
* 设第四只猴子拿【暂不说 得】到y个苹果,那么还剩下(除了扔掉的一个)4y个!而 4y=5a+1 所以 y=(5a+1)/4 .即第4只猴子得到
* (5a+1)/4 个苹果.

 

public class 第四十一题猴子分桃子_version2 { public static void main(String[] args) { // 统计次数
        int count, m, j = 0; for (int i = 4; i < 10000; i += 4) { count = 0; m = i; for (int k = 0; k < 5; k++) { j = i / 4 * 5 + 1; i = j; if (j % 4 == 0) { count++; } else 
                    break; } i = m; if (count == 4) { System.out.println("原有桃子" + j + "个"); } } } }

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



猜您在找 猴子吃桃问题。猴子第1天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。第2天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,就只剩一个桃子了。求第1天共摘多少个桃子 猴子吃桃问题。猴子第1天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。第2天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,就只剩一个桃子了。求第1天共摘多少个桃子? 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。第二天早上又将第一天剩下的桃子吃掉一半,有多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第 10 天早上想再吃时,发现只剩下一个桃子了。编写程序求猴子第一天摘了多少个桃子。 一群猴子排成一圈,按1,2,...,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去...,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号 《上帝给我一个任务,叫我牵一只蜗牛去散步》 一只蝙蝠的自述 第五题:n 只奶牛坐在一排,每个奶牛拥有 ai 个苹果,现在你要在它们之间转移苹果,使得最后所有奶牛拥有的苹果数都相同,每一次,你只能从一只奶牛身上拿走恰好两个苹果到另一个奶牛上,问最少需要移动多少次可以平分苹果,如果方案不存在输出 -1 平均分配算法 Linux 命令之split(将一个大文件根据行数平均分成若干个小文件) 关于maven的一份小笔记
 
粤ICP备18138465号  © 2018-2026 CODEPRJ.COM