2023-09-16力扣每日一题-经典DP

链接:

198. 打家劫舍

题意

有n个数字,不能选取相邻的数字,求最终选取的最大

经典DP,由于每个数字有拿与不拿两种状态,所以DPI刚好使用一个max

拿,则DPI-1不能拿,为DP[I-2]+nums[i]

不拿,则DPi-1可以拿,为DP[i-1]

两者取max

实际代码:

c++ 复制代码
#include<bits/stdc++.h>
using namespace std;
int rob(vector<int>& nums)
{
	int lg=nums.size();
	if(lg==1) return nums[0];

	vector<int>dp(lg);
	dp[0]=nums[0];dp[1]=max(nums[0],nums[1]);

 	for(int i=2;i<lg;i++)
	{
  		dp[i]=max(dp[i-1],dp[i-2]+nums[i]);
	}
	
 	return dp[lg-1];
}

限制:

  • 1 <= nums.length <= 100
  • 0 <= nums[i] <= 400
相关推荐
JieE2123 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2124 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术8 小时前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦9 小时前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户4978630507312 小时前
(一)小红的数组操作
算法·编程语言
怕浪猫15 小时前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕17 小时前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆1 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人