IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 【动态规划】【打卡114天】《剑指Offer》2刷:变态跳台阶:JZ71 跳台阶扩展问题 -> 正文阅读

[数据结构与算法]【动态规划】【打卡114天】《剑指Offer》2刷:变态跳台阶:JZ71 跳台阶扩展问题

1、题目描述

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

2、算法分析

一只青蛙一次可以跳1级,2级,...n级的台阶。求跳n阶台阶共有多少种跳法。

像这种计数的题目;比如多少种方式,多少种方法。都可以使用dp方法解题。

之前做过一道基础的题目,但是只能是跳1级或者2级。

也就是看最后一步。f[i] = f[i-1] + f[i-2];

本题:

青蛙可以跳1级,2级,...n级的台阶,所以分为5步走:

①确定dp数组以及下标含义

dp[i]:第i级台阶有多少种跳法

②确定递推公式

当target = 1,dp[1] = 1

当target = 2,dp[2] = 1+dp[1];0到1到2;0直接跳到2;

当target = 3,dp[3] = dp[2] + 1 ;dp[2]的次数再跳1步骤就可以跳到dp[3],最后 + 1是从0级台阶直接跳到第3级。

f[n] = f[n-1] + f[n-2] + ... + f[0]

③初始化

注意,这儿应该先判断target是否<2

  dp[1] = 1;
  dp[2] = 2;

④确定遍历顺序

当然是顺序遍历

3、代码实现

import java.util.*;
public class Solution {
    public int jumpFloorII(int target) {
        // 定义dp数组:dp[i]:i级台阶可以有多少种跳法
        int[] dp = new int[target+1];
        if(target <=2){
            return target;
        }
        // 初始化
        dp[1] = 1;
        dp[2] = 2;
        // 从3开始
        for(int i = 3;i <= target;i++){
            for(int j = 1;j < i;j++){
                // f[n] = f[n-1] + f[n-2] + ... + f[0]
                dp[i] += dp[j];
            }
            // 最后加的是:从0级跳到n级
            dp[i] += 1;
        }
        return dp[target];
    }
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-11-26 09:06:11  更:2021-11-26 09:08:25 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 15:37:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码