我一生之敌是状压

本文发表于

题面

给一个 \(n\) 点 \(m\) 边无向图 \(G=(V,E)\) 和一棵树,问有多少个排列 \(\{a_i\}\) 使得对于树上每一条边 \((u,v)\) 都有 \((a_u, a_v)\in E\) .

\(n\le 17\),\(m\le \dfrac 12n(n-1)\) .

题解

前置知识 - 子集反演

首先反演是啥大家都知道吧

正着的子集反演:

\[\boxed{f(S)=\sum_{T\subseteq S}g(T)\quad \Longleftrightarrow\quad g(S)=\sum_{T\subseteq S}(-1)^{|S|-|T|}f(T)}
\]

证明(抄的 vfleaking 神仙的):

Lemma.

\[\sum_{T\subseteq S}(-1)^{|T|}=|S=\varnothing|
\]

和二项式反演形式相似吧


好,回到原命题 .

\[\large\begin{aligned}g(S)&=\sum_{T\subseteq S} [S-T=\varnothing]g(T)\\&=\sum_{T\subseteq S}\sum_{R\subseteq S-T}(-1)^{|R|}g(T)\\&=\sum_{T\subseteq S}(-1)^{|T|}\sum_{R\subseteq S-T}g(R)\\&=\sum_{T\subseteq S}(-1)^{|T|}f(T-S)\\&=\sum_{T\subseteq S}(-1)^{|S|-|T|}f(T)\end{aligned}
\]

和原式长得一模一样,证毕 .


似乎 vfk 的课件里 \(p,q\) 是二进制表示的集合吧,希望我没理解错QwQ

vfk 课件偷偷在第三步换了一下变量名,坏坏

(反向子集反演:

\[f(S)=\sum_{S\subseteq T}g(T)\quad \Longleftrightarrow\quad g(S)=\sum_{S\subseteq T}(-1)^{|T|-|S|}f(T)
\]

可以看做正着反演的直接推论)

别的不说了,这里又不是「子集反演学习笔记」.

1. 朴素 dp

考虑状压 dp.

令 \(dp_{i, j, S}\) 表示 \(i\) 点表示 \(j\),已经表示了 \(S\) 状态的方案数 .

\(i,j\) 维度显然,\(S\) 是为了去重,因为 \(a\) 必须是排列 .

转移非常容易:

\[\large dp_{i, j, S}=\prod_{v\in\operatorname{son}(i)}\sum_{q\subseteq S, (j,p)\in E}dp_{v, p, q}
\]

会点计数原理(加法,乘法)就能推出来 .

时间复杂度 \(O(n^33^n)\) .

定睛一看:\(n\le 17\),寄!

2. 优化一下

看看状态,这个 \(S\) 看起来挺没用,于是直接丢掉!

没了 \(S\) 我们就不能去重了呐,所以 \(a\) 是排列这个东西就不太能保证了 .

在 \(a\) 不一定是排列的前提下,定义:

  • \(f(S)\):\(a\) 恰好使用了 \(S\) 中的所有点的方案数
  • \(g(S)\):\(a\) 至多使用了 \(S\) 中的所有点的方案数

我们要的答案就是 \(f(U)\)(\(U\) 是全集)

显然有

\[g(S)=\sum_{T\subseteq S}f(S)
\]

妈呀这不是子集反演吗,于是

\[f(S)=\sum_{T\subseteq S}(-1)^{|S|-|T|}g(T)
\]

于是我们只要求 \(g\) 即可!

\(g\) 咋求呐?考虑 dp,令 \(dp_{i, j}\) 表示 \(i\) 点表示 \(j\),在 \(g\) 的条件下的方案数 .

于是可以轻易转移(与朴素的类似)

\[\large dp_{i, j}=\prod_{v\in\operatorname{son}(i)}\sum_{p\in S, (j,p)\in E}dp_{v, p}
\]

我草这不是和朴素的一模一样吗

于是

\[\large g(S)=\sum_{k\in S}dp_{root, k}
\]

\(root\) 是树的根,你随便钦定一个就好了 .

单次 dp \(O(n^22^n)\),总时间复杂度 \(O(n^32^n)\),大体能过

细节

答案不大于 \(n!\le 355687428096000\),long long 完全能行 .

然而 \(g(S)\le n^n\le 827240261886336764177\),unsigned long long 都不行 .

我们自然可以用 __int128,但是,其实我们随便选一个幸运数字 \(M>n!\),然后答案对 \(M\) 取模就行了!

方便点,unsigned long long 自然溢出就完啦!是不是很简单

有符号整形溢出是 UB,但是我懒的改了,我代码里是有符号的 .

代码

提交记录 https://uoj.ac/submission/528128 .

吸个氧跑得飞快,不吸就会 TLE(或许是用 vector 太多了?)

自以为可读性好!

Ref.

ZJOI2016 小星星 题解的更多相关文章

  1. 【题解】P3349 [ZJOI2016]小星星 - 子集dp - 容斥

    P3349 [ZJOI2016]小星星 声明:本博客所有题解都参照了网络资料或其他博客,仅为博主想加深理解而写,如有疑问欢迎与博主讨论✧。٩(ˊᗜˋ)و✧*。 题目描述 小 \(Y\) 是一个心灵手巧 ...

  2. BZOJ 4455: [Zjoi2016]小星星 [容斥原理 树形DP]

    4455: [Zjoi2016]小星星 题意:一个图删掉一些边形成一棵树,告诉你图和树的样子,求让图上的点和树上的点对应起来有多少方案 看了很多题解又想了一段时间,感觉题解都没有很深入,现在大致有了自 ...

  3. 4455[Zjoi2016]小星星 容斥+dp

    4455: [Zjoi2016]小星星 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 527  Solved: 317[Submit][Status] ...

  4. [ZJOI2016]小星星&[SHOI2016]黑暗前的幻想乡(容斥)

    这两道题思路比较像,所以把他们放到一块. [ZJOI2016]小星星 题目描述 小Y是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有n颗小星星,用m条彩色的细线串了起来,每条细线连着两颗小星星. ...

  5. 【BZOJ 4455】 4455: [Zjoi2016]小星星 (容斥原理+树形DP)

    4455: [Zjoi2016]小星星 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 426  Solved: 255 Description 小Y是 ...

  6. 洛谷 P3349 [ZJOI2016]小星星 解题报告

    P3349 [ZJOI2016]小星星 题目描述 小\(Y\)是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有\(n\)颗小星星,用\(m\)条彩色的细线串了起来,每条细线连着两颗小星星. 有一 ...

  7. bzoj 4455 [Zjoi2016]小星星 树形dp&容斥

    4455: [Zjoi2016]小星星 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 643  Solved: 391[Submit][Status] ...

  8. 【题解】Luogu P3349 [ZJOI2016]小星星

    原题传送门 我们考虑设\(dp_{i,j}\)表示树上的点\(i\)在图上对应的点为\(j\)时\(i\)和子树对应在图上的方案数 \(dp_{u_i}=\prod_{v \in u.son} dp_ ...

  9. [ZJOI2016]小星星

    题目描述 小Y是一个心灵手巧的女孩子,她喜欢手工制作一些小饰品.她有n颗小星星,用m条彩色的细线串了起来,每条细线连着两颗小星星. 有一天她发现,她的饰品被破坏了,很多细线都被拆掉了.这个饰品只剩下了 ...

随机推荐

  1. Java 17 新特性:switch的模式匹配(Preview)

    还记得Java 16中的instanceof增强吗? 通过下面这个例子再回忆一下: Map<String, Object> data = new HashMap<>(); da ...

  2. java并发编程-StampedLock高性能读写锁

    目录 一.读写锁 二.悲观读锁 三.乐观读 欢迎关注我的博客,更多精品知识合集 一.读写锁 在我的<java并发编程>上一篇文章中为大家介绍了<ReentrantLock读写锁> ...

  3. 一条更新SQL的内部执行及日志模块

    一条更新SQL的内部执行 学习MySQL实战45讲,非常推荐学 还是老图: 上文复习 在执行查询语句的时候,会执行连接器(总要连上才能搞事情),然后去查询缓存(MySQL8+删除了),有数据返回,没数 ...

  4. 【Unity Shader学习笔记】Unity基础纹理-渐变纹理

    纹理可以用来存储任何表面属性. 可以通过使用渐变纹理来实现插画风格的渲染效果. 这项技术是由Valve公司提出的.Valve使用它来渲染游戏中具有插画风格的角色. 我们使用半兰伯特模型计算漫反射. 因 ...

  5. CF1682E Unordered Swaps

    鸽着,我不知道为什么对? 题意: 思路: code: #include<bits/stdc++.h> using namespace std; const int N=5e5+5; int ...

  6. 查询语句写了limit 1,为什么依然很慢?

    摘要: 很多时候计算引擎会对语句进行代价估计并调整语句的执行顺序.执行计划是语句如何执行的直观表达.语句如何执行不能只关注语句写法,要想写出符合预期执行顺序的查询语句,还需要关注语句执行计划. 本文分 ...

  7. Java概论——JavaSE基础

    Java概论 Java特性和优势 简单性 面向对象 可移植性 高性能:即时编译 分布式:可处理TCP/IP协议的一些东西 动态性:通过反射机制使其具有动态性 多线程:良好的交互性和实时性 安全性:防病 ...

  8. 【爬虫+情感判定+Top10高频词+词云图】"王心凌"热门弹幕python舆情分析

    目录 一.背景介绍 二.代码讲解-爬虫部分 2.1 分析弹幕接口 2.2 讲解爬虫代码 三.代码讲解-情感分析部分 3.1 整体思路 3.2 情感分析打标 3.3 统计top10高频词 3.4 绘制词 ...

  9. 【clickhouse专栏】clickhouse性能为何如此卓越

    在<clickhouse专栏>上一篇文章中<数据库.数据仓库之间的区别与联系>,我们介绍了什么是数据库,什么是数据仓库,二者的区别联系.clickhouse的定位是" ...

  10. Java JavaMail通过SMPT发送邮件

    概述 本讲讲述如何使用JavaMail工具包,通过SMPT协议,在Java代码中发送邮件. 一.JavaMail简介 JavaMail API提供了一个独立于平台且与协议无关的框架来构建邮件和消息传递 ...