高维状态机dp|环形dp

lcr90

return max(dp(nums,1),dp(nums,2)+nums0)

如何 实现 对环的处理的呢?

通过 对第一个位置的 选 不选

将dp 隔离为一个函数,两次调用~

class Solution {

vector<int> nums;

public:

int rob(vector<int>& nums)

{

if(nums.empty())

return 0;

this->nums=nums;

int n=nums.size();

++return max(nums0+solve(2,n-2),solve(1,n-1));++//nums0选 不选的预讨论

}

int solve(int a,int b)

{

if(a>b) return 0;

vector<int> t(nums.begin()+a,nums.begin()+b+1);//ok

int n=t.size();

vector<vector<int>> dp(n+1,vector<int>(2,0));//0选

for(int i=1;i<=n;i++)

{

dpi0=dpi-11+ti-1;

dpi1=max(dpi-11,dpi-10);

}

++return max(dpn0,dpn1);++

}

};

lc2708

维护"到第i位的最大乘积"和"到第i位的最小乘积"两个状态

考虑当前数与前序最大/最小乘积的乘法组合

推导出整个数组的最大小组实力值(乘积)

class Solution {

public:

long long maxStrength(vector<int>& nums) {

int const N = nums.size();

// dp0i: maximum strength from 0 - i pos.

// dp1i: minimum strength from 0 - i pos.

vector<vector<long long>> dp(2, vector<long long>(N, 0));

dp00 = nums.front();

dp10 = nums.front();

for (int i = 1; i < N; ++i) {

long long const num = numsi;

dp0i = max(max(dp0i - 1, num),

max(dp0i - 1 * num, dp1i - 1 * num));

dp1i = min(min(dp1i - 1, num),

min(dp0i - 1 * num, dp1i - 1 * num));

}

return dp0N - 1;

}

};

lc2304

bfs和floyd tle麻了,想到dp了🤡🖐🏻

  1. 定义DP状态: dpij 表示从网格第一行走到第 i 行第 j 列的最小路径成本

  2. 确定初始状态:第一行无需移动, dp0j 直接等于网格第一行对应位置的值 grid0j

  3. 推导状态转移方程:第 i 行第 j 列的最小成本,等于上一行所有列 k 到当前列的成本(上一行成本+移动成本+当前格值)的最小值,即 ++dpij = min(dpi-1k + moveCostgrid\[i-1k]j + gridij)++

  4. 明确遍历顺序:从上到下、从左到右

  5. 确定最终结果:最后一行所有列的最小路径成本中,最小值即为整个网格的最小路径成本

(初看题目movecost确实有点长,但代码写起来还是挺丝滑的说

class Solution {

public:

int minPathCost(vector<vector<int>>& grid, vector<vector<int>>& moveCost) {

auto dp = grid;

int m = grid.size(),n = grid.back().size();

for(int i = 1; i < m; ++i){

for(int j = 0; j < n; ++j){

int base = gridij;

dpij = INT_MAX;

for(int k = 0; k < n; ++k){

++dpij = min(dpij,
dpi - 1k + moveCostgrid\[i - 1k]j + base);
++

}

}

}

return *(min_element(dp.back().begin(),dp.back().end()));

}

};

相关推荐
To_OC7 分钟前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK2 小时前
线段树维护区间 k 次方和
c++·数学·算法·stl
_清歌14 小时前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局14 小时前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象14 小时前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局14 小时前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法
统计实现局14 小时前
dqrsl 拆解:拿着 QR 结果能算出哪 5 种东西
算法
统计实现局15 小时前
为什么 Cholesky 求逆比 Gauss-Jordan 快一倍——行列式溢出防护详
算法
To_OC1 天前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode