首页 > 其他分享 >西北工业大学oj题-兔子生崽

西北工业大学oj题-兔子生崽

时间:2024-09-03 09:24:27浏览次数:8  
标签:生崽 oj int months 兔子 西北工业大学 rabbitPairs public dp

题目描述:

兔子生崽问题。假设一对小兔的成熟期是一个月,即一个月可长成成兔,每对成兔每个月可以生一对小兔,一对新生的小兔从第二个月起就开始生兔子,试问从一对兔子开始繁殖,一年以后可有多少对兔子?

这道题目一眼看过去就是典型的递归问题,代码如下

public class RabbitReproduction {
    public static void main(String[] args) {
        int months = 12;
        System.out.println("After " + months + " months, there will be " + rabbitPairs(months) + " pairs of rabbits.");
    }

    public static int rabbitPairs(int n) {
        if (n == 1 || n == 2) {
            return 1;
        }
        return rabbitPairs(n - 1) + rabbitPairs(n - 2);
    }
}

递归方法:rabbitPairs 使用递归来计算每个月的兔子对数。这个问题类似于斐波那契数列:
第一个月和第二个月有 1 对兔子。
从第三个月开始,每个月的兔子对数等于前两个月的兔子对数之和。

但是这道题目虽然简单,但是递归方法可能会导致性能问题。

public class RabbitReproduction {
    public static void main(String[] args) {
        int months = 12;
        System.out.println("After " + months + " months, there will be " + rabbitPairs(months) + " pairs of rabbits.");
    }

    public static int rabbitPairs(int n) {
        if (n == 1 || n == 2) {
            return 1;
        }

        int[] dp = new int[n + 1];
        dp[1] = 1;
        dp[2] = 1;

        for (int i = 3; i <= n; i++) {
            dp[i] = dp[i - 1] + dp[i - 2];
        }

        return dp[n];
    }
}
  • 数组 dp:用于存储每个月的兔子对数。
  • 初始条件dp[1] 和 dp[2] 都设为 1,因为第一个月和第二个月只有一对兔子。
  • 状态转移方程dp[i] = dp[i - 1] + dp[i - 2]。这表示每个月的兔子对数等于前一个月和前两个月兔子对数之和。
  • 循环:从第三个月开始逐月计算,直至第 n 个月

这种方法主要是避免了递归带来的性能问题,效率更高。

标签:生崽,oj,int,months,兔子,西北工业大学,rabbitPairs,public,dp
From: https://blog.csdn.net/m0_46290969/article/details/141845325

相关文章

  • POJ - 3071
    概率题。本蒟蒻不会概率dp,于是手搓枚举。反正爆枚够用后记:SadBee的想法考虑维护每队对上上一队/下一队的胜率。只有两队最简单,用1乘即可那多队呢?不如看成两队。见:P(1胜)=P(1战胜2)P(3战胜4)P(1战胜3)+P(1战胜2)P(4战胜3)P(1战胜4)P(2胜)=......
  • 每日OJ_牛客_蘑菇阵(在矩阵上dp)
    目录牛客_蘑菇阵(在矩阵上dp)解析代码牛客_蘑菇阵(在矩阵上dp)蘑菇阵__牛客网解析代码        类似于走迷宫,蘑菇代表不能走通,但不同的是,迷宫可以向前后左右四个方向移动,但该题走的方式只能向右或者向下两个方向移动,注意:右边界处只能向一个方向移动,因此走不通......
  • 一个练习项目,好玩的bbs-perl-mojolicious
    代码:#!D:/software/Strawberry/perl/bin/perl.exeBEGIN{push(@INC,'D:/workspace/studys/study_bbs');}useMojolicious::Lite-signatures;useutf8;useNet::MySQL;useEncode;usePOSIX;useJSONqw/encode_jsondecode_json/;useDigest;o......
  • LOJ #6089. 小 Y 的背包计数问题 题解
    Description小Y有一个大小为\(n\)的背包,并且小Y有\(n\)种物品。对于第\(i\)种物品,共有\(i\)个可以使用,并且对于每一个\(i\)物品,体积均为\(i\)。求小Y把该背包装满的方案数为多少,答案对于\(23333333\)取模。定义两种不同的方案为:当且仅当至少存在一种物品的......
  • Project 2021图文安装教程及下载
    MicrosoftProject是一个国际上享有盛誉的通用的项目管理工具软件,凝集了许多成熟的项目管理现代理论和方法,可以帮助项目管理者实现时间、资源、成本的计划、控制。MicrosoftProject不仅可以快速、准确地创建项目计划,而且可以帮助项目经理实现项目进度、成本的控制、分析和预......
  • BZOJ 4403序列统计题解
    缅怀zxc......
  • BZOJ2961 共点圆
    小学数学题题意进行转化:询问点\((X,Y)\),是否满足\(\forall_{i\inS}(X-x_i)^2+(Y-y_i)^2\lex_i^2+y_i^2\)。简单化简一下得到:\(X^2+Y^2\le2Xx_i+2Yy_i\)。也就是要维护\(2Xx_i+2Yy_i\)的最小值。\(2Xx_i+2Yy_i<2Xx_j+2Yy_j\)\(=X(x_i-x_j)<Y(y......
  • appsettins.json 复制到输出文件夹 CopyToOutpuDirectory 配置文件 csproj
    复制配置文件到输出文件夹<ItemGroup><NoneUpdate="appsettings.json"><CopyToOutputDirectory>Always</CopyToOutputDirectory></None><NoneUpdate="nlog.config"CopyToOutputDirectory="Always&qu......
  • POJ1321-棋盘问题
    POJ从23号崩了,放弃POJ(也不知是不是有比赛把oj都关了),各大OJLeetcode/PAT各种花里胡哨开会员能数据,它不配正经刷题牛客网招聘多课程广告多我焦虑不想入hdoj和洛谷不错,找了找搜索算法的题目单,之前看过数一巨巨写的知乎:邝斌带你飞专题,无限回忆西安艾教培训,卿俊888上交知乎咨询,科技......
  • 安卓11报错:Failed to resolve: com.github.xxxx:14.0 Show in Project Structure dial
    本篇文章主要讲解,安卓11版本情况下项目运行报错Failedtoresolve:com.github.getActivity:Toaster:14.0ShowinProjectStructuredialogAffectedModules:app的主要原因及解决办法。作者:任聪聪独立博客:https://rccblogs.com/631.html日期:2024年8月28日具体......