兔子繁衍问题

7-2 兔子繁衍问题

分数 15

全屏浏览

切换布局

作者 徐镜春

单位 浙江大学

一对兔子,从出生后第3个月起每个月都生一对兔子。小兔子长到第3个月后每个月又生一对兔子。假如兔子都不死,请问第1个月出生的一对兔子,至少需要繁衍到第几个月时兔子总数才可以达到N对?

输入格式:

输入在一行中给出一个不超过10000的正整数N。

输出格式:

在一行中输出兔子总数达到N最少需要的月数。

输入样例:

30

输出样例:

9

1.分析

兔子过两个月后就可以生兔子了,即dp[i]=dp[i-1]+dp[i-2];就是当月的兔子数量等于上个月兔子的数量dp[i-1],加上本月新生的兔子的个数dp[i-2]。

2.代码

cpp 复制代码
#include<iostream>
using namespace std;
const int MAX=11111;
int N,re,arr[MAX];
int main(){
    cin>>N;
    int sum=0;
    arr[0]=1,arr[1]=1;
    while(sum<N){
        for(int i=0;i<=re;i++){
            if(i>=2) arr[i]=arr[i-1]+arr[i-2];      //下标从0开始,判断2
            sum=arr[i];
        }
        re++;
    }
    cout<<re<<endl;
    return 0;
}
相关推荐
努力学算法的蒟蒻5 分钟前
day43(12.24)——leetcode面试经典150
算法·leetcode·面试
XXYBMOOO8 分钟前
理解 C++ 中的字节序转换函数 `swapEndian`
开发语言·arm开发·c++
毕加锁16 分钟前
深度解析昇腾Catlass:C++模板元编程与高性能算子开发范式(1)
开发语言·c++
jianfeng_zhu19 分钟前
二叉树的一些基本运算
算法
元亓亓亓21 分钟前
LeetCode--279. 完全平方数--中等
算法·leetcode·动态规划
TimberWill30 分钟前
哈希-03-字母异位词分组
算法·哈希算法
你好音视频32 分钟前
FFmpeg FLV编码器原理深度解析
c++·ffmpeg·音视频
轻微的风格艾丝凡33 分钟前
matlab推导QPR离散公式并验证
算法·matlab·谐振
Cowboy hat1 小时前
数据结构基础(一)—— 什么是数据结构?
数据结构
Qt学视觉1 小时前
PaddlePaddle-2wget下载安装
c++·人工智能·paddlepaddle