当前位置: 首页 > news >正文

P2014 [CTSC1997] 选课

题目

P2014 [CTSC1997] 选课

算法标签: 动态规划, 树上 d p dp dp

思路

非常显而易见的树上 d p dp dp问题, 可以考虑状态表示 f [ u ] [ j ] f[u][j] f[u][j]代表以 u u u为根节点的子树 分配 j j j个节点的最大价值

树形 d p dp dp解法代码

在递归之前先使用父节点更新当前节点信息, 在递归之后使用子节点更新父节点信息, 这样统计的信息是全面的

#include <iostream>
#include <algorithm>
#include <cstring>using namespace std;const int N = 310, M = N << 1;int n, m;
int head[N], ed[M], ne[M], idx;
int w[N];
int f[N][M];void add(int u, int v) {ed[idx] = v, ne[idx] = head[u], head[u] = idx++;
}void dfs(int u, int cnt) {if (cnt <= 0) return;for (int i = head[u]; ~i; i = ne[i]) {int v = ed[i];for (int k = 0; k < cnt; ++k) f[v][k] = f[u][k] + w[v];dfs(v, cnt - 1);for (int k = 1; k <= cnt; ++k) f[u][k] = max(f[u][k], f[v][k - 1]);}
}int main() {ios::sync_with_stdio(false);cin.tie(0), cout.tie(0);memset(head, -1, sizeof head);cin >> n >> m;for (int i = 1; i <= n; ++i) {int fa;cin >> fa >> w[i];if (fa) add(fa, i);else add(0, i);}dfs(0, m);int ans = f[0][m];cout << ans << "\n";return 0;
}

树上背包问题解法代码

定义状态表示 f [ u ] [ i ] [ j ] f[u][i][j] f[u][i][j]表示以 u u u为根节点的子树中考虑 i i i个子节点并且总的体积不超过 j j j的所有方案中, 价值最大的方案, 因为是 d f s dfs dfs进行状态转移, 可以像 01 01 01背包问题一样优化掉一维, 但是第二维的体积需要反向枚举

#include <iostream>
#include <algorithm>
#include <cstring>using namespace std;const int N = 310, M = N << 1;int n, m;
int head[N], ed[M], ne[M], idx;
int f[N][M];void add(int u, int v) {ed[idx] = v, ne[idx] = head[u], head[u] = idx++;
}void dfs(int u) {for (int i = head[u]; ~i; i = ne[i]) {int v = ed[i];dfs(v);for (int j = m; j >= 0; --j) {for (int k = 0; k < j; ++k) {f[u][j] = max(f[u][j], f[u][j - k] + f[v][k]);}}}
}int main() {ios::sync_with_stdio(false);cin.tie(0), cout.tie(0);memset(head, -1, sizeof head);cin >> n >> m;m++;for (int i = 1; i <= n; ++i) {int fa;cin >> fa >> f[i][1];add(fa, i);}dfs(0);int ans = f[0][m];cout << ans << "\n";return 0;
}

相关文章:

  • 比亚迪“双剑”电池获中汽中心权威认证,堪称“移动安全堡垒”。
  • 创建vue项目
  • 基于若依的邮件登陆功能
  • 关于 smali:3. Smali 与 APK 结构理解
  • 构建智慧校园门户:技术架构与实践指南
  • 银发团扎堆本地游,“微度假”模式如何盘活银发旅游市场?
  • Autodesk Maya 2025.3新特性
  • halcon高斯滤波
  • AI如何颠覆财务预测?——用Python打造自动化智能分析系统
  • JSONP跨域原理全解析
  • vue2使用el-tree实现两棵树间节点的拖拽复制
  • 计算机网络实验课(三)——直接使用数据构造以太网帧,打包并发送|使用SharpPcap库函数构造以太网帧,并发送出去
  • 【Webtrees 手册】第 8章 - 网站管理员指南
  • 在 Unity 中,Start 方法直接设置 RectTransform 的位置,时出现问题,与预计位置不匹配。
  • LightGBM的python实现及参数优化
  • 从十进制到二进制:深入理解定点数与浮点数表示
  • Python学习(2) ----- Python的类型
  • 多模态大语言模型arxiv论文略读(九十五)
  • Python正则表达式:30秒精通文本处理
  • Java中数组(一维/二维)与字符串操作(String/StringBuilder/StringBuffer)详解
  • wordpress sqlite/杭州seo全网营销
  • 太原建站模板系统/优化网络搜索引擎
  • 商业网站的域名代码/营销软文模板
  • 互联网网站建设 选择题/seo刷网站
  • 营销网站主题有哪些内容/百度统计
  • 苏州公司网站设计/小广告设计