贝尔数--Codeforces908E. New Year and Entity Enumeration
给n<=50个长度m<=1000的二进制数,记他们为集合T,求满足下面条件的集合S数:令$M=2^m-1$,1、$a \epsilon S \Rightarrow a \ \ xor \ \ M \epsilon S$;2、$a \epsilon S,b \epsilon S \Rightarrow a \ \ and \ \ b \epsilon M$;3、$T \subseteq S$;4、S中每个数都<=M。答案膜1e9+7。
首先不看这T个数,先想想自由状态下有多少个S。由条件1可知,对m个二进制位,S中一定有一个数使得这一位不为空。那么经过若干的and操作就可以把含这一位(i)的数变小变小再变小,变到最小记f(i)。可以发现$f(x) \neq f(y) \Rightarrow f(x) \ \ and \ \ f(y) =0$。如果不这样,那么$f(x) \ \ and \ \ (f(y)\ \ xor \ \ M)$可以得到一个比f(x)更小的,且在x这一位为1的数,就矛盾。
那么自由状态下就相当于把m个位置划分成若干个集合,每个集合里的x的f(x)共享,比如{2,4}对应f(2)=f(4)=1010,问有多少方案。这就是贝尔数了。
贝尔数性质:转自此

n^2递推的话还有:令$B(0,0)=1,B(i,0)=B(i-1,i-1),B(i,j)=B(i-1,j-1)+B(i,j-1)$,则$B(i,0)$就是第i个贝尔数。
OK现在加入T的限制。在T的限制下,令R(i)表示数位i在n个数的状态,就是R(i)的第j位表示第j个数的第i位是1还是0。R(i)不同的两位,在分配集合时绝对绝对不能分在一个集合,因为如果$R(x) \neq R(y),f(x) = f(y)$,那么f(x)与那个导致两个R不相同的数and一下,就可以得到一个更小的f(x),矛盾。所以根据R(i)的不同把位分成若干组,每组算一个贝尔数即可。
//#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<map>
//#include<bitset>
#include<algorithm>
//#include<cmath>
using namespace std; int n,m;
#define LL long long
LL state[],str[][];
map<LL,int> mp;
const int mod=1e9+;
int main()
{
scanf("%d%d",&m,&n); LL x;
for (int i=;i<n;i++)
for (int j=;j<m;j++)
scanf("%1lld",&x),state[j]|=(x<<i);
for (int i=;i<m;i++) mp[state[i]]++;
str[][]=;
for (int i=;i<=m;i++)
{
str[i][]=str[i-][i-];
for (int j=;j<=i;j++) str[i][j]=str[i][j-]+str[i-][j-],str[i][j]-=str[i][j]>=mod?mod:;
}
int ans=;
for (map<LL,int>::iterator i=mp.begin();i!=mp.end();i++) ans=1ll*ans*str[(*i).second][]%mod;
printf("%d\n",ans);
return ;
}
贝尔数--Codeforces908E. New Year and Entity Enumeration的更多相关文章
- 【CodeForces】908 E. New Year and Entity Enumeration
[题目]E. New Year and Entity Enumeration [题意]给定集合T包含n个m长二进制数,要求包含集合T且满足以下条件的集合S数:长度<=m,非和与的结果都在集合中. ...
- 【CF908E】New Year and Entity Enumeration 位运算+DP
[CF908E]New Year and Entity Enumeration 题意:给定$M=2^m-1$,我们称一个集合S是好的,当且仅当它满足:1.$\forall a\in S,a\ \ma ...
- 贝尔数(来自维基百科)& Stirling数
贝尔数 贝尔数以埃里克·坦普尔·贝尔(Eric Temple Bell)为名,是组合数学中的一组整数数列,开首是(OEIS的A000110数列): Bell Number Bn是基数为n的集合 ...
- HDU 2512 一卡通大冒险(第二类斯特林数+贝尔数)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2512 题目大意:因为长期钻研算法, 无暇顾及个人问题,BUAA ACM/ICPC 训练小组的帅哥们大部 ...
- bzoj 3501 PA2008 Cliquers Strike Back——贝尔数
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3501 用贝尔三角形 p^2 地预处理 p 以内的贝尔数.可以模(mod-1)(它是每个分解下 ...
- bzoj 3501 PA2008 Cliquers Strike Back —— 贝尔数
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3501 用贝尔三角预处理贝尔数,拆模数并在 \( p \) 进制下使用公式,因为这样每次角标增 ...
- hdu2643&&hdu2512——斯特林数&&贝尔数
hdu2643 题意:$n$ 个人的排名情况数($n \leq 100$) 分析:考虑 $n$ 个有区别的球放到 $m$ 个有区别的盒子里.无空盒的方案数为 $m!\cdot S(n, m)$. 这题 ...
- hdu4767 Bell——求第n项贝尔数
题意 设第 $n$ 个Bell数为 $B_n$,求 $B_n \ mod \ 95041567$.($1 \leq n \leq 2^{31}$) 分析 贝尔数的概念和性质,维基百科上有,这里 ...
- Good Bye 2017 E. New Year and Entity Enumeration
先按照绿点进行分块 第一个绿点和最后一个绿点之后很好处理不说了 两个绿点之间的讨论: 有两种方案 1:红(蓝)点和绿点顺序连接,距离为相邻绿点距离(也就是双倍绿点距离) 2:红(蓝)点和绿点的点阵中寻 ...
随机推荐
- Spirng MVC +Velocity 表单绑定命令对象
通常,表单中的数据在提交之后可以通过Spring MVC的@RequestParam注解在控制器函数的参数列表中中提取出来,但是一旦表单数据过多的话,参数列表将会变得非常长,最好的解决方案是将表单中的 ...
- AJPFX关于java 知识点的集合
1 .对象的初始化 (1 )非静态对象的初始化 在创建对象时,对象所在类的所有数据成员会首先进行初始化. 基本类型:int 型,初始化为0. 如果为对象:这些对象会按顺序初始化. ※在所有类成员初始化 ...
- [BZOJ2002][Hnoi2010]Bounce弹飞绵羊 LCT
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2002 建图,每次往后面跳就往目标位置连边,将跳出界的点设为同一个点.对于修改操作发现可以用 ...
- PHP(二)常用函数
数学函数 数组函数 字符串函数
- php中字符与字节的区别
字符: 字符是可使用多种不同字符方案或代码页来表示的抽象实体.例如,Unicode UTF-16 编码将字符表示为 16 位整数序列,而 Unicode UTF-8 编码则将相同的字符表示为 8 位字 ...
- vue路由细节探讨
1.使用router-link 不会让页面刷新,使用a标签会使页面刷新.2.router-link 里面的to="/路由地址" tag=""自定义标签" ...
- vsphere中的linux虚拟机安装vmware-tools
先在vcenter中选中虚拟机点击安装这个工具,如图 然后这台linux虚拟机的控制台操作,挂载先建立挂载目录 cd /mnt #在挂载建一个用来挂载的文件. mkdir cdrom 使用mount命 ...
- Vue+Bootstrap实现购物车程序(3)
效果展示:(说明:使用webpack重构购物车程序,使用vue-cli生成项目脚手架) 文件结构: 代码: (1)将原来编写的btn-grp组件单独编写到BtnGrp.vue文件中 可以看到现在代码清 ...
- Spring Cloud和Dubbo的对比
- scrollfix.js插件:滚动固定在某个位置
插件文件在/文件 scrollfix.js 用法: var fix = $(".fix"), fixtop = $(".fix-top"), fixStartT ...