尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

洛谷 P8189

洛谷 P8189
📅 发布时间:2026/6/19 11:43:58

洛谷 P8189

有 \(n\) 个礼物分配给 \(n\) 个人,第 \(i\) 个人原本拥有第 \(i\) 个礼物,每个人都要一个喜欢程度的列表,现在他们可以交换礼物,但每个人最后得到的礼物的喜欢程度不能低于原本的礼物。

\(T\) 组询问,每组询问将 \(n\) 个人分成两组,两组独立的交换,问有几种分配方式。

\(n \le 18, T \le 10^5\)

不难发现这个交换方式一定是形成了若干个环。具体一点,如果第 \(p_i\) 个礼物最后在第 \(i\) 个人手里,那么有一条 \((p_i, i)\) 的有向边,第 \(i\) 个礼物需要给下一个人。

有一个比较显然的状压 DP,令 \(dp(S)\) 表示集合 \(S\) 内的人与 \(S\) 对应的礼物对应的方案数。(例如第 \(1, 3\) 个人与第 \(1, 3\) 个礼物配对)转移显然可以枚举子集,\(dp(S) = dp(S') \cdot f(S \cap S')\)。其中 \(f(S)\) 表示 \(S\) 中的元素能形成多少种环?

于是就只用求 \(f(S)\) 了。我们将这个环断开,以 \(\min \{S\}\) 为开头形成一条链,令 \(g(S, i)\) 表示 \(S\) 内的元素形成一条以 \(\min \{ S\}\) 为开头,\(i\) 为结尾的链。只用检查一下能否把两端相连即可。

时间复杂度:\(O(3^n)\)。应该可以使用子集卷积之类的东西优化,详情可以看看题解。

注意为了不算重,可以强制令 \(\min \{ S \}\) 不在 \(S'\) 内,而在 \(f\) 的环内。

思路还是比较顺畅,根据需要的东西一步一步分解问题,设计状态转移即可。

相关新闻

  • 12/8
  • 计算机毕业设计springboot图书销售框架设计与构建 基于 SpringBoot 的在线书城营销平台构建与实战 SpringBoot 驱动的数字化图书商城系统研发
  • 题解:P14666 [KenOI 2025] 游走题

最新新闻

  • 石家庄黄金回收正规军在哪?2026实测门店星级榜,卖金前看一眼 - 奢侈品回收测评
  • 深度学习进阶(三十一)FlashAttention:IO 感知的精确注意力
  • 6个免费方法让你的手机视频秒变MP4 - 软件工具教程方法
  • Kali Linux实战:ARP欺骗攻击原理、环境搭建与Wireshark流量分析
  • 杭州靠谱品牌首饰回收排行,光谱验金透明称重全款现结 - 奢品小当家
  • 2026年安徽省合肥市合肥医药卫生学校招生简章官网发布:报名入口+报考指南 - cc江江

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号