• 09.变态跳台阶 Java


    题目描述

    一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。

    思路

    0:0
    1:(1)
    2:(1,1)(2)
    3:(1,1,1)(2,1)(1,2)(3)
    4:(1,1,1,1)(2,1,1)(1,2,1)(3,1)(1,1,2)(1,3)(2,2)(4)
    
    显然,除了0,其他都是2^(n-1);
    OJ并未检查小于等于0的情况,所以也可将该界外判断去掉。
    
    n级台阶,第一步有n种跳法:1,2,3,...,n
    跳1级,剩下的有F(n-1)种。
    跳2级,剩下的有F(n-2)种。
    ...
    跳n级,剩下的有F(0)=1种。
    所以F(n)=F(n-1)+F(n-2)+...+F(0)
    因为F(n-1)=F(n-2)+F(n-3)+...+F(0)
    所以F(n)=2*F(n-1)
    

    代码

    public class Solution {
        public int JumpFloorII(int target) {
            if(target <= 0){
                return 0;
            }
            int temp=1;
            while(target >=2){
                temp *=2;
                target--;
            }
            return temp;
        }
    }
    public class Solution {
        public int JumpFloorII(int target) {
            if(target <= 0){
                return 0;
            }
            return (int)Math.pow(2,target-1);
        }
    }
    public class Solution {
        public int JumpFloorII(int target) {
            if(target <= 0){
                return 0;
            }
            return 1 << (target -1);
        }
    }
    public class Solution {
        public int JumpFloorII(int target) {
            if(target <= 0){
                return 0;
            }else if(target == 1){
                return 1;
            }
            return 2*JumpFloorII(target-1);
        }
    }
  • 相关阅读:
    [ Luogu 3398 ] 仓鼠找sugar
    [ JLOI 2014 ] 松鼠的新家
    AtcoderGrandContest 005 F. Many Easy Problems
    Codeforces 388 D. Fox and Perfect Sets
    Codeforces 1037 H. Security
    「学习笔记」wqs二分/dp凸优化
    「NOI2017」游戏
    「SCOI2014」方伯伯的商场之旅
    「SCOI2015」情报传递
    「SCOI2016」美味
  • 原文地址:https://www.cnblogs.com/feicheninfo/p/10522571.html
Copyright © 2020-2023  润新知