「清华集训2014-主旋律」题解

news/2025/10/21 21:51:48/文章来源:https://www.cnblogs.com/LastKismet/p/19156500

P11714 [清华集训 2014] 主旋律

pref

怎么新赛季就开始了。

一直想补岁月,但至今没有实现,也就只好先从主旋律下手。

我该在哪里停留?我问我自己。

sol

题意就是求删后原图仍强联通的有向边删边方案数。

强联通是不好刻画的,考虑非强联通。不难发现,其满足缩点之后是一个 DAG,先从 DAG 下手。

考虑刻画 DAG,不难想到拓扑,从而考虑到可以从入度为 \(0\) 的点入手,这些点删完之后得到的图仍然是 DAG,于是可以考虑从这里入手 DP。

令点集 \(S\) 的生成 DAG 方案数为 \(dp(S)\),记 \(f(T)\) 表示 \(S\) 内有且仅有 \(T\) 点集中的点入度为 \(0\) 的方案数,则有转移:

\[dp(S)=\sum_{\varnothing\subsetneqq T\subseteq S} f(T) \]

容斥求 \(f\),记 \(g(T)\) 为钦定 \(T\) 点集中的点入度为 \(0\) 的方案数,\(E_{S,T}\)\(S\) 点集连向 \(T\) 点集的边数,显然有:

\[g(T)=2^{E_{T,S-T}}dp(S-T) \]

则有:

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

计算 \(dp(S)\)

\[\begin{aligned} dp(S)&=\sum_{\varnothing\subsetneqq T\subseteq S}\sum_{T\subseteq R\subseteq S}(-1)^{|R|-|T|}g(R)\\ &=\sum_{\varnothing\subsetneqq R\subseteq S}(-1)^{|R|}\sum_{\varnothing\subsetneqq T\subseteq R}(-1)^{|T|}g(R)\\ &=\sum_{\varnothing\subsetneqq R\subseteq S}(-1)^{|R|}(-[R=\varnothing])g(R)\\ &=\sum_{\varnothing\subsetneqq R\subseteq S}(-1)^{|R|+1}g(R)\\ &=\sum_{\varnothing\subsetneqq T\subseteq S}(-1)^{|T|+1}2^{E_{T,S-T}}dp(S-T) \end{aligned} \]

考虑拓展到缩点前的原图上,记 \(dp(S)\) 表示 \(S\) 是个 SCC 的方案数,\(g(T)\) 表示钦定 \(T\) 中点缩成若干入度为 \(0\) 的点的方案数,我们尝试仿照上面的式子写转移式,但不难发现容斥系数无法得到,其原因是无法得知 \(T\) 中的点到底缩成了几个入度为 \(0\) 的点。

考虑把容斥系数融入到 \(g\) 的定义中去,那么 \(g(S)\) 表示 \(S\) 中点缩成奇数个入度为 \(0\) 的点的方案数减去 \(S\) 中点缩成偶数个入度为 \(0\) 的点的方案数的值。在此之后求 \(g\) 其实也没有变得很困难,钦定一个子集视作新加入的来转移即可,强制令其包含 \(S\) 中某一个定点,比如 \(\mathrm{lowbit}(S)\) 代表元素,即可得到:

\[g(S)=dp(S)-\sum_{T\subset S\land \mathrm{lowbit}(S)=\mathrm{lowbit}(T)}dp(T)g(S-T) \]

也就是缩成一个 SCC 的方案数,减去新加 SCC 的方案数。后者是因为新加一个块块数奇偶性改变,相当于乘了一个容斥系数 \(-1\)

得到 \(g\) 之后即可得到 \(dp\)

\[dp(S)=2^{E(S,S)}-\sum_{T\subseteq S}2^{E_{T,S-T}+E_{S-T,S-T}}g(T) \]

特别的,当 \(S=T\) 时,\(g(S)\) 此时不应加上 \(dp(S)\),考虑组合意义理解一下即可。那么就是先算 \(g(S)\) 不加上 \(dp(S)\),再算得 \(dp(S)\),最后给 \(g(S)\) 加回去即可。

然后压力给到 \(E\) 的计算,这个东西现在状态数 \(4^n\),成为了瓶颈。然而不难发现,我们只会用到 \(E_{S,S},E_{T,S-T}\) 这两种形式的状态,故而状态数实际上只需要 \(3^n\)。考虑随 \(S\) 动态更新这两个东西,定义 \(I_v\) 为连向点 \(v\) 的点集,\(O_v\) 为点 \(v\) 连向的点集,每次钦定集合内一个点 \(u\)(比如 \(\mathrm{lowbit}\))转移即可,有:

\[E_{S,S}=E_{S-u,S-u}+|I_u\cap S|+|O_u\cap S|\\ E_{T,S-T}=E_{T+u,S-T-u}-|O_u\cap(S-T)|+|I_u\cap T| \]

于是这个问题结束了。最后复杂度为 \(O(3^n)\)

code

const int N=15,S=1<<N;int n,m;
int out[N],in[N],lg[S],e1[S],e2[S];
mint f[S],g[S],pt[N*N];inline void Main(){cin>>n>>m;pt[0]=1;rep(i,1,n*n)pt[i]=pt[i-1]*2;lg[1]=0;rep(i,2,1<<n-1)lg[i]=lg[i>>1]+1;rep(i,1,m){int a,b;cin>>a>>b;--a,--b;out[a]|=1<<b;in[b]|=1<<a;}repl(s,1,1<<n){int x=s&-s;e2[s]=e2[s^x]+__builtin_popcount(s&in[lg[x]])+__builtin_popcount(s&out[lg[x]]);}repl(s,1,1<<n){e1[s]=0;for(int t=s-1&s;t;t=t-1&s){int x=s-t&t-s;e1[t]=e1[t|x]-__builtin_popcount(s-t&out[lg[x]])+__builtin_popcount(t&in[lg[x]]);}for(int t=s-1&s;t;t=t-1&s){if((s&-s)!=(t&-t))continue;g[s]-=f[t]*g[s^t];}f[s]=pt[e2[s]];for(int t=s;t;t=t-1&s)f[s]-=g[t]*pt[e1[t]+e2[s^t]];g[s]+=f[s];}put(f[(1<<n)-1]);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/942692.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Hetao P5593 删 题解 [ 蓝 ] [ 线性 DP ] [ DFS 序 ] [ 虚树 ]

删:思路很新奇的一道 DP 题。 通常做树形 DP 都是自底向上进行 DP 的,而此题因为转移与 DFS 序有关,所以可以拍在 DFS 序上 DP。 观察删除的性质,发现一个点 \(u\) 要么被删掉,不进行匹配,要么就必须要与 \(\bm{…

第二次高级程序作业

2025高级语言程序设计 https://edu.cnblogs.com/campus/fzu/gjyycx/homework/13570 102500426康凯帆书本外额外的题目程序清单3.11练习题 做完这些练习题,让我对于c语言有了更深的了解,以往都是听理论模模糊糊,现在…

大学生需要认真听课的肌肉记忆(注意力训练)

原文:Scalers:大学生上课为什么一定要认真听讲? https://www.scalerstalk.com/816-attention2) 读这篇文我有很深的共鸣,以及一些困惑的解答。 原文说,认真听讲是一种能力,我在读大学一年后无比赞同。事实上不…

Ancestral Problem 题解

逆天卡常匈牙利吊打 dinic 下面默认二分图匹配的复杂度是 \(\mathcal{O}(m\sqrt n)\),其中 \(n\) 是点数,\(m\) 是边数。 暂时默认 \(m=\mathcal{O}(n)\) 因为不影响分析复杂度。首先容易写出 \(\mathcal{O}(n^{3.5}…

AWS IAM角色最佳实践:构建云安全的核心防线

本文深入探讨AWS IAM角色的核心概念与最佳实践,涵盖身份识别、权限管控、威胁检测和自动响应等关键环节,通过具体配置示例展示如何有效保护云环境安全,避免权限滥用和潜在威胁。AWS IAM角色最佳实践 Amazon Web Ser…

初始人工智能和机器学习

一、初始人工智能 1.人工智能是一个抽象的概念,它不是任何具体的机器或算法。任何类似于人的智能或高于人的智能的机器或算法都可以称为人工智能。应用:机器人等。 2.机器学习是AI系统需要具备自我学历的能力,即从原…

盒子模型外边距合并问题

两个外边距重合时,那个大用哪个 当只给子级盒子创建顶部外边距时,会连带着父级盒子一起隔离 第一种:取消子级外边距,给父级加内边距(加内边距会撑大盒子) 规避撑大盒子 2.给父级溢出的部分给隐藏 3.加细边框线显示出多…

o(N^2)找出所有回文子串

1、对于一个字符串如果(i - 1, j - 1)为回文串,并且s[i] == s[j],那么(i, j)也是一个回文串 2、双重循环,外层从大到小,内层从小到大,这样就可以由小区间推到大区间(可以写下思考一下)int vis[2010][2010];mems…

蛋白表达技术概述

一、蛋白表达的定义 蛋白表达(Protein Expression) 是指通过人工构建的基因表达系统,在特定宿主细胞中合成目标蛋白的过程。在自然界中,基因经转录和翻译形成蛋白质,这是生命活动的基本过程。在实验和工业生产中,…

二叉树的中序遍历- 递归原理 - MKT

二叉树的中序遍历- 递归原理

二叉树的中序遍历- 二叉树基本-栈 - MKT

二叉树的中序遍历- 二叉树基本-栈 前序遍历非递归实现​​:void preorderIterative(TreeNode* root) {if (root == nullptr) return;stack<TreeNode*> s;s.push(root);while (!s.empty()) {TreeNode* node = s…

二叉树的中序遍历- 二叉树基本-递归 - MKT

二叉树的中序遍历- 二叉树基本-递归 #include <iostream> #include <queue> using namespace std;struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(nullptr…

二叉树的中序遍历- 递归和栈 - MKT

二叉树的中序遍历- 递归和栈 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) …

构建YouTube视频总结摘要智能体

构建YouTube视频总结摘要智能体智能体 AI 平台 智能体 AI 框架是一个工具包,用于创建能够通过工具使用和记忆自主或半自主地推理、计划和采取行动的智能体系统。这些框架提供了创建能够与环境交互、做出决策和执行…

友链测试

// run new Vue({el: #app,data: {links: [{name: 捞月亮の小北,desc: 言念君子,温其如玉,avatar: https://youke1.picui.cn/s1/2025/10/21/68f785af89315.png,url: https://example.com},{name: Fomalhaut,desc: Fut…

English writing practice in diary.

Recent Situation Overview Currently everything around is horrible, but hopful(hopeful) too. Learning English for TOEFL, studying major ourse for upgradation(academic improvement) and devoting in web3 r…

以此文记我的国漫生活

原来我以前看过这么多动画片和动漫,来看看你看过哪些: 《喜羊羊与灰太狼》《熊出没》《猪猪侠》《猫和老鼠》《成龙历险记》《十二生肖闯江湖》《大头儿子和小头爸爸》《神兵小将》《舒克贝塔》《疯狂小糖》《葫芦娃…

做了一个概率小游戏,没想到服务器被打爆被攻击了!原因竟然是他?真没想到...

做了一个概率小游戏,没想到服务器被打爆被攻击了!原因竟然是他?真没想到。让我给大家讲讲我怎么和攻击者在线上斗智斗勇的。1. 前言 事情是这样的,上个月在刷知乎的过程中,发现了以下几个有趣的问题。《每毫秒给你…

接下来的目标

本学期目标: 1.学完redis黑马点评,掌握关于redis,分布式锁,秒杀等知识点 2.八股文在javaguide上观看一遍 3.算法题hot100刷第一遍 4.看完《深入理解jvm虚拟机》目前已看完历史即第一章,准备编译openjdk12; 5.写完…

敬启,致那时的我

题面 题目描述 实乃理给你两个整数 \(S, k\),你需要帮她求出以下式子的值对 \(1,000,000,007\) 取模的结果: \[\sum_{X = 0}^S [\mathrm{popc}(X) = k]F(X) \]其中 \(F\) 为斐波那契数列,即 \(F(0) = F(1) = 1, F(n…