news 2026/1/7 11:08:14

状态机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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/25 18:28:39

AI社交工具如何提升跨文化沟通效率

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个跨文化沟通效率对比工具&#xff0c;比较传统翻译工具与AI辅助社交工具的效果差异。要求&#xff1a;1. 设计3种典型沟通场景&#xff1b;2. 记录传统方式和AI方式的沟通时…

作者头像 李华
网站建设 2025/12/25 9:40:59

微电网储能系统充放电分布式协同优化探秘

关键词&#xff1a;微电网&#xff1b;储能系统&#xff1b;一致性算法&#xff1b;充放电分布式协同优化&#xff1b; ## 非完整复现&#xff0c;控制部分未做;主题&#xff1a;在微电网系统中&#xff0c;储能系统(ESSs)常被用来支持频率控制。 由于可再生能源发电的间歇性和…

作者头像 李华
网站建设 2026/1/4 19:10:25

[GPU] TileLang vs Triton: 选择合适的GPU编程语言

在众多GPU编程语言中如何做出选择&#xff0c;当前GPU编程生态系统中的一个重要趋势——越来越多的高级抽象语言正在挑战传统的CUDA编程模式。 背景&#xff1a;两个相似却不同的选择 TileLang和Triton都是基于现代编译器技术的GPU编程语言&#xff0c;旨在简化CUDA开发。 Tr…

作者头像 李华
网站建设 2025/12/27 6:13:07

AI写论文哪个软件最好?别被“秒出万字”骗了——真正能交毕业论文的,只有它敢带真实图表、真实数据、真实文献

“AI写论文”广告铺天盖地&#xff1a; “3分钟生成全文”“一键搞定毕业论文”“导师看不出是AI写的”…… 但当你真拿它交初稿&#xff0c;才发现—— ❌ 参考文献是编的&#xff08;DOI查无此号&#xff09; ❌ 图表全是占位符或“AI幻想图” ❌ 数据“准确率98.7%”&#…

作者头像 李华
网站建设 2025/12/26 21:27:19

AI如何帮你快速分析Linux磁盘使用情况

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个AI驱动的Linux磁盘分析工具&#xff0c;能够自动扫描指定目录的磁盘使用情况&#xff0c;并以可视化图表展示占用空间最大的文件和目录。支持按大小、修改时间等维度排序&a…

作者头像 李华
网站建设 2025/12/26 13:03:16

用Wireshark快速验证网络服务的5种端口检测方法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个网络服务快速检测工具原型&#xff0c;集成Wireshark常用端口检测方案。用户选择服务类型&#xff08;如Web、邮件、数据库&#xff09;后&#xff0c;自动生成对应的过滤表…

作者头像 李华