高维状态机dp|环形dp

lcr90

return max(dp(nums,1),dp(nums,2)+nums[0])

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

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

将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(nums[0]+solve(2,n-2),solve(1,n-1));++//nums[0]选 不选的预讨论

}

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++)

{

dp[i][0]=dp[i-1][1]+t[i-1];

dp[i][1]=max(dp[i-1][1],dp[i-1][0]);

}

++return max(dp[n][0],dp[n][1]);++

}

};

lc2708

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

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

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

class Solution {

public:

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

int const N = nums.size();

// dp[0][i]: maximum strength from 0 - i pos.

// dp[1][i]: minimum strength from 0 - i pos.

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

dp[0][0] = nums.front();

dp[1][0] = nums.front();

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

long long const num = nums[i];

dp[0][i] = max(max(dp[0][i - 1], num),

max(dp[0][i - 1] * num, dp[1][i - 1] * num));

dp[1][i] = min(min(dp[1][i - 1], num),

min(dp[0][i - 1] * num, dp[1][i - 1] * num));

}

return dp[0][N - 1];

}

};

lc2304

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

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

  2. 确定初始状态:第一行无需移动, dp[0][j] 直接等于网格第一行对应位置的值 grid[0][j]

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

  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 = grid[i][j];

dp[i][j] = INT_MAX;

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

++dp[i][j] = min(dp[i][j],
dp[i - 1][k] + moveCost[grid[i - 1][k]][j] + base);
++

}

}

}

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

}

};

相关推荐
m0_629494733 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户3 小时前
用队列实现栈
数据结构·算法
做人求其滴3 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad7773 小时前
记一组无人机IMU传感器数据
算法
计算机安禾3 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
小O的算法实验室4 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-4 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~4 小时前
运动控制系统复习一览-----常考题目总结版本
算法
小短腿的代码世界4 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构