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

链接:

198. 打家劫舍

题意

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

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

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

不拿,则DP[i-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
相关推荐
Sɪʟᴇɴᴛ໊ོ2353 分钟前
Anyview数据结构第一章(按需自取)
c语言·开发语言·数据结构·算法
松岛雾奈.2307 分钟前
机器学习--数据集的标准化和归一化算法;随机森林
人工智能·算法·机器学习
橘颂TA15 分钟前
【剑斩OFFER】算法的暴力美学——丢失的数字
数据结构·算法·leetcode·结构与算法
努力的白熊嗨17 分钟前
大文件 Hash 计算:Web Worker 并行优化的原理与局限性
javascript·算法
CoovallyAIHub36 分钟前
存储风暴下的边缘智能韧性:瑞芯微RK3588如何将供应链挑战转化为市场机遇
深度学习·算法·计算机视觉
杜子不疼.41 分钟前
【C++】解决哈希冲突的核心方法:开放定址法 & 链地址法
c++·算法·哈希算法
落羽的落羽1 小时前
【Linux系统】解明进程优先级与切换调度O(1)算法
linux·服务器·c++·人工智能·学习·算法·机器学习
Ka1Yan1 小时前
[数组] - LeetCode 704. 二分查找
java·开发语言·算法·leetcode·职场和发展
2501_941881401 小时前
区块链技术:颠覆金融与未来社会的力量
leetcode
@卞2 小时前
高阶数据结构 --- 单调队列
数据结构·c++·算法