【视频+图文】Java经典基础练习题(六):猴子吃桃子问题
一、具体题目
猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个
第二天 早上又将剩下的桃子吃掉一半 ,又多吃了一个 。
以后每天早上都吃了前一天剩下的一半零一个。
到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少个桃。
二、思路分析(逆向思维)
- 第10天时的桃子数:1
| 第10天桃子总数 | 1个 |
|---|
- 第9天桃子总数:4
根据【以后每天早上都吃了前一天剩下的一半零一个。】
我们可以先从1往上推测数字。
我们可以做出以下假设:
| 假设第9天桃子数量为2 | 2-(2/2+1)= 0 | 不满足第10天还剩1个的条件 |
|---|---|---|
| 假设第9天桃子数量为3 | 3-(3/2+1) | 除不尽,不满足条件 |
| 假设第9天桃子数量为4 | 4-(4/2+1)= 1 | 满足第10天还剩一个桃的条件 |
所以就可以确定第9天桃子总数为4
| 第9天桃子总数 | 第9天吃掉的桃子数 | 第9天剩余的桃子数 |
|---|---|---|
| 4 | 4/2+1=3 | 4-3=1 |
将第10天桃子数和第9天桃子数关联起来得到下面的式子:
4=1*2+1+1
- 有了第9天桃子总数就可以求出第8天桃子总数
根据题目中的条件列一个方程式:每天早上都吃了前一天剩下的一半零一个。
第8天的桃子总数=第8天吃掉的桃子总数+第8天剩余的桃子总数(第9天的桃子总数) - 因为第8天剩余的桃子会放到第9天去吃
- 第8天剩余的桃子总数=第9天的桃子总数
设:第8天有桃子x个: x = (x/2+1)+4 x=10
即第8天有桃子10个
| 第8天桃子总数 | 第8天吃掉的桃子数 | 第8天剩余的桃子数 |
|---|---|---|
| 10 | 10/2+1=6 | 10-6=4 |
将第9天桃子数和第8天桃子数关联起来得到下面的式子:
10=4*2+1+1
- 同理可以求出第7天桃子总数:
第7天的桃子总数=第7天吃掉的桃子总数+第7天剩余的桃子总数(第8天的桃子总数)
因为第7天剩余的桃子会放到第8天去吃
第7天剩余的桃子总数=第8天的桃子总数
设:第7天有桃子x个: x = (x/2+1)+10 x=22
即第7天有桃子22个
| 第7天桃子总数 | 第7天吃掉的桃子数 | 第7天剩余的桃子数 |
|---|---|---|
| 22 | 22/2+1=12 | 22-12=10 |
将第8天桃子数和第7天桃子数关联起来得到下面的式子:
22=10*2+1+1
所以我们可以看出:
- 第10天桃子数:1
- 第9天桃子数:1*2+1+1=4
- 第8天桃子数:4*2+1+1=10
- 第7天桃子数:10*2+1+1=22
三、代码+结果
代码:
package Exercise;
public class HouZiChiTao {
/*
* 第10天桃子数:1
* 第9天桃子数:1*2+1+1=4
* 第8天桃子数:4*2+1+1=10
* 第7天桃子数:10*2+1+1=22
*/
public static void main(String[] args) {
int m = 1;//第10天剩余的桃子数
for (int i = 9; i > 0; i--) {//采用逆推的思维
m = m * 2 + 1+1;
}
System.out.println(m);
}
}
结果:

四、彩蛋
欢迎大家来公号 “小乔的编程内容分享站”
来找小乔玩~
一起学习Java基础+算法~
还有更多资源等你来拿哦~

【视频+图文】Java经典基础练习题(六):猴子吃桃子问题的更多相关文章
- 【视频+图文】Java经典基础练习题(三):输入3个整数,并将其由小到大输出
目录 一.视频讲解 二.思路分析 总结: 三.代码+详解+结果 四.彩蛋 能解决题目的代码并不是一次就可以写好的 我们需要根据我们的思路写出后通过debug模式找到不足再进行更改 多次测试后才可得到能 ...
- Java语言基础(六)
Java语言基础(六) 前一章提到的, BigDecimal, DecimalFormat等具体用法,这里就不在说了,网上有许多 一.下面让我们看一个例子(自由落体运动位移) 说明: (1).公式是 ...
- Java 多线程基础(六)线程等待与唤醒
Java 多线程基础(六)线程等待与唤醒 遇到这样一个场景,当某线程里面的逻辑需要等待异步处理结果返回后才能继续执行.或者说想要把一个异步的操作封装成一个同步的过程.这里就用到了线程等待唤醒机制. 一 ...
- 超全面!1.5w字总结50个Java经典基础面试题(已根据知识点分类)
大家好,我是fancy. 在面试中将基础问题回答好就是成功的一半. 我总结了50道经典的Java基础面试题,里面包含面试要回答的知识重点,并且我根据知识类型进行了分类,可以说非常全面了. 小伙伴们点赞 ...
- java并发基础(六)--- 活跃性、性能与可伸缩性
<java并发编程实战>的第9章主要介绍GUI编程,在实际开发中实在很少见到,所以这一章的笔记暂时先放一放,从第10章开始到第12章是第三部分,也就是活跃性.性能.与测试,这部分的知识偏理 ...
- Java Script基础(六) DOM模型
一.文档对象模型 DOM( Document Object Model)文档对象模型,它提供了访问.动态修改文档的借口,W3C指定了DOM规范,主流浏览器都支持.DOM由3部分组成,分别是CoreDo ...
- Java语言基础(六)char成员变量默认初始值 最简单的Java源文件 Java的main()方法
①char成员变量的初始值是:'\u0000' ②package用来指定该文件所处的包的名称,必须位于源文件的顶端. import java.util.*; package com.hyy.test; ...
- Java经典基础与高级面试36题和答案
1.”static”关键字是什么意思?Java中是否可以覆盖(override)一个private或者是static的方法? “static”关键字表明一个成员变量或者是成员方法可以在没有所属的类的实 ...
- java语言基础(六)_String类_static_Arrays类_Math类
String类 1. 使用 java.lang.String类代表字符串.lang包含的包不用特意引用,即默认已经引用了. API当中说:Java 程序中的所有字符串字面值(如 "abc&q ...
随机推荐
- 用纯Python实现循环神经网络RNN向前传播过程(吴恩达DeepLearning.ai作业)
Google TensorFlow程序员点赞的文章! 前言 目录: - 向量表示以及它的维度 - rnn cell - rnn 向前传播 重点关注: - 如何把数据向量化的,它们的维度是怎么来的 ...
- 建议8:恰当选用if和switch
相对来说下面几种情况更适合switch结构 枚举表达式的值.这种枚举是可以期望的,平行逻辑关系的 表达式的值具有离散性,不具有线性的非连续的区间值 表达式的值是固定的,不是动态变化的 表达式的值是有限 ...
- RabbitMQ消息发布和消费的确认机制
前言 新公司项目使用的消息队列是RabbitMQ,之前其实没有在实际项目上用过RabbitMQ,所以对它的了解都谈不上入门.趁着周末休息的时间也猛补习了一波,写了两个窗体应用,一个消息发布端和消息消费 ...
- [剑指offer]10.斐波那契数列+青蛙跳台阶问题
10- I. 斐波那契数列 方法一 Top-down 用递归实现 def fibonacci(n): if n <= 0: return 0 if n == 1: return 1 return ...
- ajax原理及封装
一:AJAX 简介 AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术,通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新. AJAX = 异步 JavaScri ...
- msys2 mingw64安装
(1)安装msys2 (2)更新\etc\pacman.d\下的源文件 mirrorlist.msys Server = http://repo.msys2.org/msys/$arch/ Serve ...
- ReentrantLock源码解析——虽众但写
在看这篇文章时,笔者默认你已经看过AQS或者已经初步的了解AQS的内部过程. 先简单介绍一下ReentantLock,跟synchronized相同,是可重入的重量级锁.但是其用法则相当不同,首先 ...
- OpenCV-Python 傅里叶变换 | 三十
目标 在本节中,我们将学习 使用OpenCV查找图像的傅立叶变换 利用Numpy中可用的FFT函数 傅立叶变换的某些应用程序 我们将看到以下函数:cv.dft(),cv.idft()等 理论 傅立叶变 ...
- SG函数(斐波那契博弈) Fibonacci again and again
https://zhuanlan.zhihu.com/p/53948422 HDU - 1848 将这篇文章认真的看了一遍 ,虽然不是很懂 ,但是脑子里有了一个模型,链接里的图 (看的顺序 是 0,1 ...
- SpringCloud-Nacos/OpenFien/Gateway的基本介绍及快速上手
一.Spring-Cloud-Alibaba-Nacos 注册中心 1.下载.安装 Nacos 下载地址:https://github.com/alibaba/nacos/releases 下载后解压 ...