P3214 [HNOI2011] 卡农 题解
感觉不是很麻烦,可能就组合排列转化绕一点。。。
抽象化题意
给定 \(n\) 个元素,从中选出 \(m\) 个集合,要求:
集合不为空,集合里不能有相同的元素
\(m\) 个集合都互不相同
所有元素被选出的次数为偶数
求方案数,并对 \(100000007\) 取模
凭感觉是DP+组合数
设 \(dp[i][0/1]\) 表示当前选了 \(i\) 个集合合法还是不合法的方案数,但是转移不好转移,因为我们并不知道哪些集合非法,所以我们不能将非法当成状态,只能把他放到转移里,怎么转移?考虑容斥。
若先满足第三个条件,那么就是 \(A^{i-1}_{2^n-1}\) ,因为取决奇偶的只会是最后一个,所以前面 \(i-1\) 任取。
还有两个条件,第一个条件怎么搞?“不能有相同元素”我们已经在第三个条件考虑过了,那我们先强制集合为空,所贡献的就是 \(dp[i-1]\) 种方案,所以减掉 \(dp[i-1]\) 。
最后一个,第二个条件怎么处理?容斥,当前考虑第 \(i\) 个集合,需要和前 \(i-1\) 个集合任意一个相同,且当前 \(i\) 集合的取法有 \(2^n-1-(i-2)\) 种,剩余 \(i-2\) 个集合是合法的,就是 \((i-1)(2^n-i+1)dp[i-2]\) 种
转移方程就是 \(dp[i]=A^{i-1}_{2^n-1}-dp[i-1]-(i-1)(2^n-i+1)dp[i-2]\) ,因为我们算得是排列,所以最后要除以 \(m!\) ,当然转移的时候也可以转成组合,就不需要除以 \(m!\) 了
#include<bits/stdc++.h>
#define int long long
#define maxn 2000005
const int mod=1e8+7;
using namespace std;
template<class T>
inline T read(){
T r=0,f=0;
char c;
while(!isdigit(c=getchar()))f|=(r=='-');
while(isdigit(c))r=(r*10)+(c^48),c=getchar();
return f?-r:r;
}
int n,m;
int dp[maxn],pow2,A[maxn];
inline int mypow(int a,int b){
int ret=1;
while(b){
if(b&1)ret=(ret*a)%mod;
a=(a*a)%mod,b>>=1;
}
return ret;
}
signed main(){
n=read<int>();
m=read<int>();
if(n==1&&m==1){puts("1");return 0;}
pow2=mypow(2,n);
A[1]=pow2-1;
int tmp=pow2-1,facm=1;
for(int i=2;i<=m;i++)
A[i]=A[i-1]*(--tmp)%mod,facm=facm*i%mod;
dp[1]=0,dp[0]=1;
for(int i=2;i<=m;i++){
dp[i]=((A[i-1]-dp[i-1]+mod)%mod-(i-1)*(pow2-i+1)%mod*dp[i-2]%mod+mod)%mod; //pow2[n]-1-(i-2)
}
// for(int i=1;i<=m;i++)cout<<dp[i]<<endl;
printf("%lld\n",dp[m]*mypow(facm,mod-2)%mod);
return 0;
}
P3214 [HNOI2011] 卡农 题解的更多相关文章
- P3214 [HNOI2011]卡农
题目 P3214 [HNOI2011]卡农 在被一题容斥\(dp\)完虐之后,打算做一做集合容斥这类的题了 第一次深感HNOI的毒瘤(题做得太少了!!) 做法 求\([1,n]\)组成的集合中选\(m ...
- [HNOI2011]卡农 题解
题目描述 众所周知卡农是一种复调音乐的写作技法,小余在听卡农音乐时灵感大发,发明了一种新的音乐谱写规则.他将声音分成 n 个音阶,并将音乐分成若干个片段.音乐的每个片段都是由 1 到 n 个音阶构成的 ...
- 洛谷 P3214 - [HNOI2011]卡农(线性 dp)
洛谷题面传送门 又是一道我不会的代码超短的题( 一开始想着用生成函数搞,结果怎么都搞不粗来/ll 首先不妨假设音阶之间存在顺序关系,最终答案除以 \(m!\) 即可. 本题个人认为一个比较亮的地方在于 ...
- 【BZOJ2339】[HNOI2011]卡农 组合数+容斥
[BZOJ2339][HNOI2011]卡农 题解:虽然集合具有无序性,但是为了方便,我们先考虑有序的情况,最后将答案除以m!即可. 考虑DP.如果我们已经知道了前m-1个集合,那么第m个集合已经是确 ...
- [BZOJ2339][HNOI2011]卡农
[BZOJ2339][HNOI2011]卡农 试题描述 输入 见"试题描述" 输出 见"试题描述" 输入示例 见"试题描述" 输出示例 见& ...
- bzoj2339[HNOI2011]卡农 dp+容斥
2339: [HNOI2011]卡农 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 842 Solved: 510[Submit][Status][ ...
- BZOJ2339[HNOI2011]卡农——递推+组合数
题目链接: [HNOI2011]卡农 题目要求从$S=\{1,2,3……n\}$中选出$m$个子集满足以下三个条件: 1.不能选空集 2.不能选相同的两个子集 3.每种元素出现次数必须为偶数次 我们考 ...
- [HNOI2011]卡农 (数论计数,DP)
题面 原题面 众所周知卡农是一种复调音乐的写作技法,小余在听卡农音乐时灵感大发,发明了一种新的音乐谱写规则. 他将声音分成 n n n 个音阶,并将音乐分成若干个片段.音乐的每个片段都是由 1 1 1 ...
- [HNOI2011]卡农
题目描述 众所周知卡农是一种复调音乐的写作技法,小余在听卡农音乐时灵感大发,发明了一种新的音乐谱写规则.他将声音分成 n 个音阶,并将音乐分成若干个片段.音乐的每个片段都是由 1 到 n 个音阶构成的 ...
- 【bzoj2339】[HNOI2011]卡农 dp+容斥原理
题目描述 题解 dp+容斥原理 先考虑有序数列的个数,然后除以$m!$即为集合的个数. 设$f[i]$表示选出$i$个集合作为满足条件的有序数列的方案数. 直接求$f[i]$较为困难,考虑容斥,满足条 ...
随机推荐
- AcWing 4495. 数组操作题解
思路 此题较为简单,简述一下思路. 从小到大排序,每次选取最小值,只要不为0即可 每次都为序列减去一个数字太慢,但每个数又减去的数字一样,所以可以用minus记录每个数要减去的数 C++代码 #inc ...
- Microsoft edge锁定在任务栏上,被修改主页360的解决方法
今天从桌面下边的任务栏打开Microsoft edge浏览器,突然发现主页被篡改为360导航了(生气!恶龙咆哮ooo 在桌面上是Microsoft edge,固定到任务栏就成为Microsoft ed ...
- 我真的想知道,AI框架跟计算图什么关系?PyTorch如何表达计算图?
目前主流的深度学习框架都选择使用计算图来抽象神经网络计算表达,通过通用的数据结构(张量)来理解.表达和执行神经网络模型,通过计算图可以把 AI 系统化的问题形象地表示出来. 本节将会以AI概念落地的时 ...
- 如何在 Windows Server 2022 阿里云服务器上搭建自己的 MQTT 服务器之二Mosquitto服务器
一.介绍 最近几天都在搭建MQTT服务器,几天前搭建好了一个 Apache-Apollo的 MQTT 服务器,当我们在管理我们的主题的时候,发现主题的名称的斜杠(/)变成了点号(.),正好我在调试程序 ...
- pssh 安装使用
which python # 查看python 是否指向 python2 ll /usr/bin/python # lrwxrwxrwx. 1 root root 7 2020-03-24 03:08 ...
- Bug_ku source (WEB) wp
在源代码中注释中发现了flag,提交发现是假的. 我们打开kali用dirserch扫描一下网站后台目录吧 发现.git ,这题应该是一个git泄露的题,用wget吧文件下载到本地,-r 选项的作用是 ...
- openpyxl 统一表格样式
# 统一表格样式 rows = ws.max_row columns = ws.max_column # print(rows) # print(columns) for row in range(1 ...
- 四 APPIUM GUI讲解(Windows版)(转)
Windows版本的APPIUM GUI有以下图标或者按钮: ·Android Settings - Android设置按钮,所有和安卓设置的参数都在这个里面 ·General Settings – ...
- 需求太多处理不过来?MoSCoW模型帮你
一.MoSCoW模型是什么 MoSCoW模型是在项目管理.软件开发中使用的一种排序优先级的方法,以便开发人员.产品经理.客户对每个需求交付的重要性达成共识. MoSCoW是一个首字母缩略词,代表: M ...
- 青少年CTF平台-Web-PingME
题目描述 题目难度一颗星,五十分. 解题记录 进入题目中,发现这是一个ping功能 我们用连字符||进行分割两个语句,保证同时运行且输出. Payload为127.0.0.1 || ls 发现有fla ...