猴子偷桃php代码,C++实现猴子吃桃的示例代码

题目详情

有一天,某只猴子摘了一些桃子,当时吃了一半,又不过瘾,于是就多吃了一个。以后每天如此,到第n天想吃时,发现就只剩下一个桃子。输入n,表示到第n天剩下1个桃子,请计算第一天猴子摘的桃子数。程序运行结果如下:

10

1534

要求

时间限制:2000ms

内存限制:32000kb

输入格式:

输入一个整数n,n>0,表示到第n天剩下1个桃子。

输出格式:

一个整数,表示第1天摘的桃子数。

输入样例:

10

输出样例:

1534

个人思路

根据题意,设想第0天是第一天刚摘桃子没吃的时候。

其实第n天发现想吃的时候只有一个桃子的时候

其实是第(n-1)天吃完一半再减一个桃子,也就是就剩最后一个桃子了。

对于夹在中间的天数有这样规律的递推

an+1 = an/2 - 1

反过来也就是an = 2*an+1 + 2,

这样用递归也就可以

从第(n-1)天倒推回第0天(第一天刚摘桃子没吃的时候)的桃子总数。

天数

总数

0

sum

1

sum/2 + 1

2

(sum/2-1)/2 -1

3

((sum/2-1)/2 -1)/2 - 1

下面代码

#include

using namespace std;

int main()

{

int Geshu(int day, int n);

int n;

cin>>n;

cout<

return 0; //也就是第(n-1)天吃完后就剩最后一个桃子了

}

int Geshu(int sum, int day)

{

if(day==0) //设想第0天是第一天刚摘桃子没吃的时候

return sum;

return Geshu(2*sum+2,day-1);

}

到此这篇关于C++实现猴子吃桃的示例代码的文章就介绍到这了,更多相关C++ 猴子吃桃内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2020-02-26

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值