【动态规划】整数划分及其变种

简介: 笔记

1. 整数划分【不可重复,考虑顺序,完全背包】


900. 整数划分20.png

思路

题意转为完全背包求解。21.png


代码

int n; cin >> n;
for (int i = 0; i <= n; i++) f[i][0] = 1;
for (int i = 1; i <= n; i++){
    for (int j = 1; j <= n; j++) {
        f[i][j] = f[i - 1][j] % mod;
        if(j >= i) f[i][j] = (f[i - 1][j] + f[i][j - i]) % mod;
    }
}
cout << f[n][n] << endl;
  • 压缩一维
g[0] = 1;
for (int i = 1; i <= n; i++)
    for (int j = i; j <= n; j++) 
        g[j] = (g[j] + g[j - i]) % mod;
cout << g[n] << endl;

2. 鸣人的影分身【可重复,不考虑顺序,>=0】


1050. 鸣人的影分身


22.png


思路

可重复型 & 二维费用完全背包


题意:n 拆成 m 份的方案数,换句话说就是用 m 个数拼成 n的方案数。


每个数可以选多次(≥ 0 \geq 0≥0),就是完全背包问题,受体积和份数限制,即二维费用完全背包。


f [ i ] [ j ]: 表示体积为 i 时,划分 j 份的方案数。

23.png

代码

cin >> n >> m;
f[0][0] = 1;
for (int i = 0; i <= n; i++) 
    for (int j = 1; j <= m; j++) {
        f[i][j] = f[i][j - 1];
        if (i >= j) f[i][j] = (f[i][j - 1] + f[i - j][j]) % mod; 
    }
cout << f[n][m] << endl;

3. 数的划分【可重复,不考虑顺序,>=1】


[编程题]数的划分

24.png



思路

与上题不同的是,分的每份都不能为空,即 ≥ 1 \geq 1≥1。


f[i][j]: 表示体积为 i 时,划分 j 份的方案数。25.png

代码

int n, m; cin >> n >> m;
vector<vector<int>> f(n + 1, vector<int>(m + 1, 0)); 
f[0][0] = 1;
const int mod = 1e9 + 7;
for (int i = 1; i <= n; i++) {
    for (int j = 1; j <= i && j <= m; j++) {
        f[i][j] = (f[i - 1][j - 1] + f[i - j][j]) % mod;
    }
}
cout << f[n][m] << endl;


相关文章
|
16天前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
6020 30
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
1天前
|
数据采集 人工智能 前端开发
让 Coding Agent 从黑盒到透明:阿里云 Agent 观测审计数据采集实践
AI Agent 规模化落地带来执行黑盒、行为难追溯、成本难度量三大难题。阿里云基于 OTel 标准,面向 Coding Agent、个人通用助理和框架型 Agent,推出 LoongSuite Pilot、插件及探针等无侵入采集方案,让 Agent 实现可看见、可分析、可审计、可治理。
572 135
|
11天前
|
存储 定位技术 数据库
CodeGraph 如何让 Claude Code减少 7 成工具调用?
CodeGraph 为 Coding Agent 提供本地代码知识图谱,把函数、类、调用链和框架路由提前整理成“项目地图”,减少盲目搜索和文件读取。它不是新 Agent,而是上下文基础设施,让 Agent 更快找到正确代码路径,平均减少 7 成工具调用。
1189 3
|
8天前
|
人工智能 安全 定位技术
CodeGraph深度解析 让Claude Code工具调用直降七成的核心原理与实操教程
如今以Claude Code为代表的AI编程智能体已经成为开发者日常编码、项目重构、漏洞修复的必备工具。但在长期使用过程中,几乎所有开发者都会遇到同一个明显痛点:AI虽然具备强大的代码生成与分析能力,却常常陷入盲目探索的循环中。
992 1
|
18天前
|
人工智能 自然语言处理 供应链
|
9天前
|
人工智能 弹性计算 安全
阿里云618活动时间、活动入口、优惠活动详细解读
2026年阿里云618创新加速季已全面开启,作为年度力度最大的云产品促销活动,本次大促覆盖轻量应用服务器、ECS云服务器、GPU云服务器、数据库、AI算力、安全服务、CDN等全品类产品,推出5亿元算力补贴、新用户限时秒杀、普惠满减、企业专享、免费试用、云大使返佣等多重福利,个人开发者、中小企业、AI团队均可享受专属低价。本文将系统梳理2026年阿里云618活动的完整时间节点、官方参与入口、各类优惠细则、使用规则、热门产品推荐及实操代码,帮助用户精准参与、高效省钱,以最低成本完成上云部署。
814 5
|
9天前
|
运维
欢迎报名|2026 Agentic AICon—智能体基础设施与AgentOps专场,邀您参会
欢迎报名|2026 Agentic AICon—智能体基础设施与AgentOps专场,邀您参会
1442 0