简单多状态问题

class Solution {

public:

int massage(vector<int>& nums) {

int n=nums.size();

if(n==0) return 0;

vector<int> f(n);

auto g=f;

f0=nums0;

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

fi=gi-1+numsi;

gi=max(fi-1,gi-1);

}

return max(fn-1,gn-1);

}

};

class Solution {

public:

int rob(vector<int>& nums) {

int n=nums.size();

return max(nums0+money(nums,2,n-2),money(nums,1,n-1));

}

int money(vector<int>&nums,int left,int right){

int n=nums.size();

if(left>right) return 0;

vector<int> f(n);

auto g=f;

fleft=numsleft;

for(int i=left+1;i<=right;i++){

fi=gi-1+numsi;

gi=max(gi-1,fi-1);

}

return max(fright,gright);

}

};

class Solution {

public:

int deleteAndEarn(vector<int>& nums) {

const int N=10001;

int arrN={0};

for(auto e :nums){

arre+=e;

}

vector<int> f(N);

auto g=f;

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

fi=gi-1+arri;

gi=max(gi-1,fi-1);

}

return max(fN-1,gN-1);

}

};

class Solution {

public:

int minCost(vector<vector<int>>& costs) {

int n=costs.size();

vector<vector<int>> dp(n+1,vector<int>(3));

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

dpi0 = min(dpi - 11, dpi - 12) + costsi - 10;

dpi1 = min(dpi - 10, dpi - 12) + costsi - 11;

dpi2 = min(dpi - 11, dpi - 10) + costsi - 12;

}

return min(dpn0, min(dpn1, dpn2));

}

};

lass Solution {

public:

int maxProfit(vector<int>& nums) {

int n=nums.size();

if(n==1) return 0;

vector<vector<int>> ret(n,vector<int>(3));

//0是买入的状态,1是可交易,2是冷却期

ret00=-nums0;

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

reti0=max(reti-10,reti-11-numsi);

reti1=max(reti-11,reti-12);

reti2=reti-10+numsi;

}

return max(retn-10,max(retn-11,retn-12));

}

};

class Solution {

public:

int maxProfit(vector<int>& nums, int fee) {

int n=nums.size();

vector<vector<int>> ret(n,vector<int>(4,-1e9));

ret00=-nums0;

ret02=0;

//0买股票,1有股票不卖,2,没有股票也不买,3,表示卖股票

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

reti0=max(reti-13-numsi,reti-12-numsi);

reti1=max(reti-10,reti-11);

reti2=max(reti-13,reti-12);

reti3=max((reti-10+numsi-fee),(reti-11+numsi-fee));

}

return max(retn-12,retn-13);

}

};

class Solution {

public:

int maxProfit(vector<int>& nums) {

int n=nums.size();

vector<vector<int>> f(n,vector<int>(3,-1e9));

auto g=f;

//f表示买入的g表示卖出

f00=-nums0,g00=0;

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

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

fij=max(fi-1j,gi-1j-numsi);

gij=gi-1j;

if(j>=1){

gij=max(gij,fi-1j-1+numsi);

}

}

}

int sum=0;

for(int i=0;i<3;i++){

sum=max(sum,gn-1i);

}

return sum;

}

};

class Solution {

public:

int maxProfit(int k, vector<int>& nums) {

int n=nums.size();

k=min(k,n/2);

vector<vector<int>> f(n,vector<int>(k+1,-1e9));

auto g=f;

f00=-nums0,g00=0;

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

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

fij=max(fi-1j,gi-1j-numsi);

gij=gi-1j;

if(j>=1){

gij=max(fi-1j-1+numsi,gi-1j);

}

}

}

int sum=0;

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

sum=max(sum,gn-1i);

}

return sum;

}

};

相关推荐
小欣加油6 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly6 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕7 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei7 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld8 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi89 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang10 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
想要成为糕糕手10 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试
KaMeidebaby11 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠11 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc