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

CF995F Cowmpany Cowmpensation

给定一棵以 \(1\) 为根的 \(n\) 个节点的树,第 \(i\) 个点的父亲为 \(p_i\)。你需要给第 \(i\) 个节点赋予一个整数点权 \(a_i\),需要满足下面的性质:

  • \(\forall i \in [1,n],a_i \in [1,D]\)

  • \(\forall i \in [2,n],a_i \leq a_{p_i}\)

求不同方案的总数。

\(1 \leq n \leq 3000\)\(1 \leq D \leq 10^9\)

考虑朴素 dp,记 \(dp_{i,j}\) 表示在以 \(i\) 为根的子树中 \(a_i \leq j\) 的填法总数,可得:

\[dp_{i,j}=dp_{i,j-1}+\prod\limits_{k \in son_i} dp_{k,j} \]

考虑到若 \(i\) 为原树的叶子节点,则 \(dp_{i,j}=j\),易知 \(dp_i\) 为关于 \(j\) 的一次多项式。由于 \(dp_{i,j}\) 为所有儿子的 \(dp_{i,j}\) 乘积的前缀和,容易发现 \(dp_{i}\) 应该是 \(k\) 次多项式,其中 \(k\)\(i\) 的子树大小,于是你算出 \(O(n)\)\(dp_{1,j}\) 的值后插值即可得到 \(dp_{1,D}\)。时间复杂度 \(O(n^2)\)

http://icebutterfly214.com/news/481/

相关文章:

  • WPF datagrid mvvm loaded 100M items,prism.wpf,prism.dryioc
  • sg.绑定键盘事件
  • 壁纸收集
  • Windows11安装miniconda
  • 10.27 CSP-S模拟40 改题记录
  • 详细介绍:Redis多租户资源隔离方案:基于ACL的权限控制与管理
  • 20251027周一日记
  • 学校协同云盘怎么选?2025年10大热门教育网盘推荐与对比
  • GPU集群之间的交互
  • CF1267G Game Relics
  • 102302115方朴第一次作业
  • 解题报告-梦熊 CSP-S2025 模拟赛T2
  • 鄙“站”麻将和算24,刷新后会换
  • 20232422 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 20232404 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 「WC2014-紫荆花之恋」题解
  • 谢谢你周医生
  • 来源未知
  • Date 10.27
  • 10.27及动手动脑
  • go包装bing搜索
  • 鼾声识别芯片方案和睡眠产品的应用场景
  • 2025年工程管理软件公司综合推荐榜:助力建筑行业数字化升级
  • Excel高性能异步导出完整方案!
  • 2025年多功能综合杆厂家排名前十推荐
  • 2025年度在线网站客服系统综合排行榜正式发布
  • JDD Oxygen智能零售论坛 | 《大模型时代的广告营销变革与实践》
  • 2025年市面上新加坡留学品牌、行业内公司及口碑产品推荐排行
  • 11-文件上传
  • TensorFlow与PyTorch深度对比分析:从基础原理到实战选择的完整指南 - 指南