【题目描写叙述】

老猴子辛苦了一辈子,给那群小猴子们留下了一笔巨大的財富——一大堆桃子。老猴子决定把这些桃子分给小猴子。

第一个猴子来了,它把桃子分成五堆,五堆一样多,但还多出一个。它把剩下的一个留给老猴子,自己拿走当中的一堆。

第二个猴子来了。它把桃子分成五堆。五堆一样多,但又多出一个。它把多出的一个留给老猴子,自己拿走当中的一堆。

后来的小猴子都如此照办。最后剩下的桃子所有留给老猴子。

这里有n仅仅小猴子,请你写个程序计算一下在開始时至少有多少个桃子,以及最后老猴子最少能得到几个桃子。

【输入】

输入包含多组測试数据。

每组測试数据包含一个整数n(1≤n≤20)。

输入以0结束,该行不做处理。

【输出】

每组測试数据相应一行输出。

包含两个整数a,b。

分别代表開始时最小须要的桃子数。和结束后老猴子最少能得到的桃子数。

【演示样例输入】

5

1

0

【演示样例输出】

3121 1025

1 1

【算法思想】

an表示第n个猴子来的时候,总共多少个桃子。

求特征函数: a1=a1-(a1-1)/5  。a1=1

求通项公式:{an+4}={a1+4}q^(n-1)={a1+4}(5/4)^(n-1)

【屌丝代码】

#include <stdio.h>
#include <iostream>
int main()
{
int n, i;
int sum, l, t;
while (scanf("%d", &n)==1 && n)
{
l = 1;
for (i=1; i<n; i++)
l *= 5;
sum = 1+5*(l-1);
t = sum;
for (i=1; i<=n-1; i++)
t = (t-1)/5*4;
printf("%d %d\n", sum, t+n);
}
printf("%d %d\n", sum, t+n);
return 0;
}

【吊轨代码】

#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int n;
long long total_num,old_num;
while(cin>>n && n!=0)
{
total_num=pow(5,n)-4;
old_num=n+pow(0.8,n)*pow(5,n)-4;
cout<<total_num<<" "<<old_num<<endl;
}
return 0;
}

【误区释疑】

1.总共一个猴子。那仅仅猴子拿到的桃子数目为Numa。总共两个猴子拿桃子,最后一个猴子拿到的桃子数目为Numb;总共三仅仅猴子拿桃子。最后一个猴子拿到的桃子数目为Numc。这里的Numa!

=Numb!=Numc;

2.查找总共多少仅仅猴子,假设按不论总共多少仅仅猴子。最后一仅仅猴子拿到的数目都是Num个,之前的猴子数目就会混淆,这里一定要区分开两个概念,总共N仅仅猴子拿到的桃子数目和第N个猴子拿到的数目是不一样的。

C++ HOJ 猴子分桃的更多相关文章

  1. Java50道经典习题-程序41 猴子分桃

    题目:海滩上有一堆桃子,五只猴子来分.第一只猴子把这堆桃子凭据分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份.第二只猴子把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿 ...

  2. JAVA 基础编程练习题41 【程序 41 猴子分桃】

    41 [程序 41 猴子分桃] 题目:海滩上有一堆桃子,五只猴子来分.第一只猴子把这堆桃子凭据分为五份,多了一个,这只猴子把 多的一个扔入海中,拿走了一份.第二只猴子把剩下的桃子又平均分成五份,又多了 ...

  3. java例题_41 利用递归给猴子分桃

    1 /*41 [程序 41 猴子分桃] 2 题目:海滩上有一堆桃子,五只猴子来分.第一只猴子把这堆桃子平均分为五份,多了一个,这只猴子把 3 多的一个扔入海中,拿走了一份.第二只猴子把剩下的桃子又平均 ...

  4. Python: 猴子分桃。海滩上有一堆桃子,五只猴子来分。

    海滩上有一堆桃子,五只猴子来分.第一只猴子把这堆桃子平均分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份.第二只猴子把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿走了一 ...

  5. 猴子分桃—Python

    def f(): for i in range(3120,4000): flag = 1 k=i for j in range(5): if i%5==1: i=(i//5)*4 else: flag ...

  6. 用python实现【五猴分桃】问题

    转载链接:https://blog.csdn.net/cy309173854/article/details/78296839 据说“五猴分桃”问题最先是由大物理学家狄拉克提出来的,这一貌似简单的问题 ...

  7. C#之猴子吃桃儿问题的解法——猴子吐桃儿

    猴子第一天摘了许多个桃子,先吃了所有桃子的一半,后又吃了一个:第二天又吃了剩下桃子的一半,后又吃了一个……第十天,剩1个桃子.问:猴子第一天摘了多少个桃子? 首先对“猴子吃桃”的过程进行正向推导,设: ...

  8. 猴子吃桃问题(南阳ACM324)

    猴子吃桃问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:0 描述 有一堆桃子不知数目,猴子第一天吃掉一半,又多吃了一个,第二天照此方法,吃掉剩下桃子的一半又多一个,天天如此, ...

  9. 猴子吃桃问题(Java递归实现)

    猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个,第二天早上又将剩下的桃子吃掉一半,又多吃了一个.以后每天早上都吃了前一天剩下的一半零一个.到第10天早上想再吃时,见只剩下 ...

随机推荐

  1. ubuntu 安装 codelite

    http://www.linuxidc.com/Linux/2013-06/85332.htm Ubuntu 12.04下为codelite增添更新源 1.获取codelite的公钥 sudo apt ...

  2. 网站中超链接方式直接添加QQ好友

    使用情景: 在图中点击图片,会弹出添加qq好友的窗口进行好友添加. 链接如下: tencent://AddContact/?fromId=45&fromSubId=1&subcmd=a ...

  3. OpenERP 负载平衡

    OpenERP 7.0 带来了许多新特性,架构上也有许多改进.其中可配置 worker 参数,可使 OpenERP 运行在多进程模式,突破GIL的限制,有效利用了现代多核CPU的性能.但默认情况下,O ...

  4. 使用quartz进行容器启动时登陆接口服务器和接口服务器进行心跳连接

    1.下载quartz的相应jar包 2.增加spring配置文件(applicationContext-quartz.xml) 内容如下: <?xml version="1.0&quo ...

  5. pip简单配置

    pip安装Python模块的工具,等价于Redhat中的yum! 01.下载 百度云盘:http://pan.baidu.com/s/1eRHGBfk             ###相关的 Linux ...

  6. Log4Net的概念和使用

    第一篇文本日志 log4net简介: log4net简介: log4net是一个功能著名的开源日志记录组件,由java平台而来. 利用log4net可以方便地将日志信息记录到文件.控制台.Window ...

  7. GitHub搭建博客过程

    1.参考 我的 Github 个人博客是怎样炼成的 http://www.jianshu.com/p/4fd3cb0a11da 到了第三节"三.使用 Jekyll 搭建个人博客"时 ...

  8. 学习Tkinter

    tutorial point这个网站教程很多,无所不包.还包括一堆在线IDE,值得收藏 一.第一个tkinter程序 import tkinter top = tkinter.Tk() # Code ...

  9. iOS - CFSocket 的使用

    1.CFSocket 苹果对对底层 BSD Socket 进行轻量级的封装(纯 C). 主要使用的 API:CFSocekt 用于建立连接,CFStream 用于读写数据. 2.基本使用 2.1 Cl ...

  10. linux的cat命令

    1 描述 cat 的全称 concatenate files and print on the standard output cat命令事Linux下的一个文本输出命令. 用于链接文件并打印到标准输 ...