【LeetCode Hot100】动态规划:T70:爬楼梯 T118:杨辉三角形 T198:打家劫舍

T70:爬楼梯

题目要求:假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

动态规划本质理解

当你达到n层时,你的上一步只能是:n-1或者n-2

也就是说:

到达 n 的方法数 =到达 n-1 的方法数+到达 n-2 的方法数

核心公式:dpn = dpn-1 + dpn-2

就是斐波那契数列:当前数字等于前两个数相加之和

代码实现

java 复制代码
if(n<=2)return n;
int a=1;
int b=2;

for(int n=3;i<n;i++){
int sum=a+b;
a=b;
b=sum;
}
return b;

总结

dpn = dpn-1 + dpn-2

是本题的解答关键

T118:杨辉三角形

题目要求:

给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行。

在「杨辉三角」中,每个数是它左上方和右上方的数的和。

杨辉三角规律

每一行:

第一个 = 1

最后一个 = 1

中间元素 = 上一行相邻两个数之和

核心思路

一行一行构造

每一行如何构造:

  1. 先放一个 1
  2. 中间用"上一行"计算
  3. 最后放一个 1

代码实现

java 复制代码
List<List<Integer>> res=new ArrayList<>();

for(int i=0;i<numRows;i++){
List<Integer> row=new ArrayList<>();
//每一行有i+1个元素
for(int j=0;j<=i;j++){
//第一个和最后一个都是1
if(j==0||j==i){
res.add(1);
}else{
//中间=上一行相邻两个数之和
int val=res.get(i-1).get(j-1)+res.get(i-1).get(j);
res.add(val);
}
}
}
return res;

总结

理解:

一行一行构造;每一行第一和最后是1;中间元素是上相邻两元素相加

T198:打家劫舍

题目要求:

有一排房子,每个房子有金额 numsi

你不能偷相邻的房子(会报警❗)

问:最多能偷多少钱?

本质

每个位置都在做"选 or 不选"的决策

核心思路

这是一个典型动态规划问题,

dpi 表示前 i 个房子的最大收益,

状态转移为 dpi = max(dpi-1, dpi-2 + numsi)

代码实现

java 复制代码
if(nums,length==1)return nums[0];
int a=nums[0];//dp[i-2]
int b=Math.max(nums[0];nums[1]);//dp[i-1]

for(int i=2;i<nums.length;i++){
int cur=Math.max(b,a+nums[i]);
a=b;
b=cur;
}
return b;

总结

每一轮做决策:

偷 or 不偷

dpi = max(dpi-1, dpi-2+numsi)

滚动变量优化

相关推荐
小雨下雨的雨4 小时前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
xieliyu.6 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
一条小锦吕*7 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
如竟没有火炬8 小时前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵
8Qi89 小时前
LeetCode 1143 & 718:最长公共子序列 / 最长重复子数组
算法·leetcode·职场和发展·动态规划
绿算技术9 小时前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
想吃火锅100510 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
net3m3311 小时前
一阶软件低通滤波器算法
人工智能·算法
水木流年追梦11 小时前
大模型入门-大模型优化方法12-YaRN 长文本外推技术
人工智能·分布式·算法·正则表达式·prompt