news 2026/6/23 9:57:23

状态机dp

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
状态机dp

lc351

memo+回溯,状态标记+对称性优化

统计手机九宫格手势密码中长度在 [m,n] 范围内的有效模式总数

class Solution {
public:
bool st[9];
int cnt;
int ans;
int c_num;
int n1[16] = {0, 0, 0, 1, 2, 2, 2, 3, 5, 6, 6, 6, 7, 8, 8, 8};
int n2[16] = {2, 8, 6, 7, 0, 6, 8, 5, 3, 0, 8, 2, 1, 2, 0, 6};
int n3[16] = {1, 4, 3, 4, 1, 4, 5, 4, 4, 3, 7, 4, 4, 5, 4, 7};
bool check(int u, int i) {

if (st[i]) return false;
for (int j = 0; j < 16; j ++) {
if (u == n1[j] && i == n2[j] && !st[n3[j]]) return false;
}
return true;
}

void dfs(int u, int m, int n) {
st[u] = true;
if (c_num >= m && c_num <= n) ans ++;
for (int i = 0; i < 9; i ++) {
if (check(u, i)) {
c_num += 1;
dfs(i, m, n);
c_num -= 1;
}
}
st[u] = false;
}

int numberOfPatterns(int m, int n) {
memset(st, false, sizeof st);
if (n == 0) return 0;
if (n == 1) return 9;
cnt = 1;
c_num = 1;
int res = 0;
dfs(0, m, n);
res += ans * 4;
ans = 0;
dfs(1, m, n);
res += ans * 4;
ans = 0;
dfs(4, m, n);
res += ans;
return res;
}
};

lc1852

hash滑窗

vector<int> distinctNumbers(vector<int>& nums, int k)
{
int n=nums.size();
unordered_map<int,int> hash;
for(int i=0;i<k;i++)
{
hash[nums[i]]++;
}
vector<int> ret(n-k+1);
ret[0]=hash.size();
for(int i=1;i<n-k+1;i++)
{
int l=nums[i-1];
int r=nums[i+k-1];
if(--hash[l]==0)
hash.erase(l);
++hash[r];
ret[i]=hash.size();
}
return ret;
}
};

lc3573

用三个二维数组记录每天、至多k+1笔交易下的多仓、做空仓、空仓利润

遍历价格更新状态后取最终k+1笔交易空仓的最大利润

class Solution {

typedef long long ll;

public:

long long maximumProfit(vector<int>& prices, int k)

{

int n = prices.size();

const ll INF = LLONG_MIN / 2;

// f[i][j]: 第i天,j次交易后 多仓(买入持有)的最大利润

// g[i][j]: 第i天,j次交易后 做空仓(卖出待买回)的最大利润

// h[i][j]: 第i天,j次交易后 空仓的最大利润

vector<vector<long long>> f(n + 1, vector<ll>(k + 2, INF));

auto g=f;

auto h=f;

// 初始化:第0天,空仓利润为0

for (int j = 1; j <= k + 1; j++)

h[0][j] = 0;

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

int p = prices[i];

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

// 空仓状态更新:延续空仓 / 多仓平仓 / 做空仓平仓

h[i + 1][j] = max({h[i][j], f[i][j] + p, g[i][j] - p});

// 多仓状态更新:延续多仓 / 前一次空仓开多

f[i + 1][j] = max(f[i][j], h[i][j - 1] - p);

// 做空仓状态更新:延续做空仓 / 前一次空仓开空

g[i + 1][j] = max(g[i][j], h[i][j - 1] + p);

}

}

return h[n][k + 1];

}

};

lc188

三维 状态机dp

“买/卖状态数组”记录每天最多k次交易后的持仓/空仓利润,先优化k的上限,再遍历价格更新状态,最后取空仓的最大利润

&看题解学到了斜率优化dpദ്ദി˶˃ ᵕ ˂ )✧!

class Solution {
public:
int maxProfit(int k, vector<int>& prices)
{
int n=prices.size();
//题目 给的 k 可能过大
k=min(k,n/2); //处理一下,优化空间

vector<vector<int>> f(n,vector<int>(k+1,-0x3f3f3f3f));
auto g=f;//卖出

g[0][0]=0;//sale
f[0][0]=-prices[0];//buy

for(int i=1;i<n;i++)
{
for(int j=0;j<=k;j++)
{
f[i][j]=max(f[i-1][j],g[i-1][j]-prices[i]);
g[i][j]=g[i-1][j];
if(j-1>=0)
g[i][j]=max(g[i-1][j],f[i-1][j-1]+prices[i]);
}
}
int ret=0;
for(int j=0;j<=k;j++)
{
ret=max(ret,g[n-1][j]);
}
return ret;
}
};

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 21:05:44

为什么网站无法打开-eshukan.com

尊敬的用户您好&#xff1a; 您访问的网站被机房安全管理系统拦截&#xff0c;可能是以下原因造成14&#xff1a; 1.您的网站未备案&#xff0c;或者原备案号被取消&#xff0c;进入备案通道. 2.您的网站未添加网站白名单&#xff0c;添加网站白名单.如果已添加&#xff0c;请等…

作者头像 李华
网站建设 2026/6/23 21:07:37

AI如何解决TLS协议版本不匹配问题

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个AI工具&#xff0c;能够自动检测服务器和客户端之间的TLS协议版本兼容性。工具应支持扫描目标服务器支持的TLS版本&#xff0c;并与客户端请求的版本进行比对&#xff0c;自…

作者头像 李华
网站建设 2026/6/17 6:00:51

查重不是“安检门”,而是你学术表达的“校音器”——宏智树AI免费查重,让引用有回响,原创有回声

在科研写作中&#xff0c;有一个被误解最深的环节&#xff1a;论文查重。 很多人把它当作一道必须硬闯的“安检门”——交稿、等待、心跳加速&#xff0c;生怕那个红色数字太高。 但真正的查重&#xff0c;不该是“被审查”&#xff0c;而应是一次对学术表达的自我校准&#x…

作者头像 李华
网站建设 2026/6/23 17:26:13

Git删除过去分支(如删除23年及之前的分支)

下面这个shell清理23年及之前的分支,在清理之前将分支显示在"branch_dates.txt"文件中 #!/bin/bashecho "开始获取远程分支的创建时间信息..."# 获取所有远程分支 branches$(git branch -r | grep -v HEAD | sed s/origin\///)# 临时文件存储分支信息 tem…

作者头像 李华
网站建设 2026/6/21 0:55:11

AB测试:数据驱动决策的科学与艺术

引言&#xff1a;从直觉到数据的决策革命在互联网产品开发中&#xff0c;我们曾经常陷入无休止的争论&#xff1a;”这个按钮应该是红色还是蓝色&#xff1f;”、”注册流程是三步好还是五步好&#xff1f;”、”新算法真的提升用户体验了吗&#xff1f;“。这些曾经依赖主观判…

作者头像 李华
网站建设 2026/6/22 12:38:44

零基础学会用vue-qrcode制作第一个二维码

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个适合Vue初学者的二维码生成教程项目&#xff0c;要求&#xff1a;1. 从零开始搭建Vue项目 2. 逐步讲解vue-qrcode的安装和使用 3. 实现一个最简单的二维码生成demo 4. 包含…

作者头像 李华