BZOJ 1494 生成树计数(生成树计数-矩阵)
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1494
题意:

思路:

int SIZE;
struct matrix
{
i64 a[N][N];
void init(int x)
{
clr(a,0);
if(x)
{
int i;
FOR0(i,SIZE) a[i][i]=1;
}
}
matrix operator*(matrix p)
{
matrix ans;
ans.init(0);
int i,j,k;
FOR0(k,SIZE) FOR0(i,SIZE) FOR0(j,SIZE)
{
ans.a[i][j]+=a[i][k]*p.a[k][j]%mod;
ans.a[i][j]%=mod;
}
return ans;
}
matrix pow(i64 n)
{
matrix ans,p=*this;
ans.init(1);
while(n)
{
if(n&1) ans=ans*p;
p=p*p;
n>>=1;
}
return ans;
}
};
matrix a;
const int val[]={1,1,1,3,16,125};
int status[N],hash[1<<15];
int S[N],K;
i64 n;
i64 c[N];
void DFS(int dep,int st)
{
if(dep==K)
{
c[SIZE]=1;
int a[10]={0},i;
FOR0(i,K) a[st>>(i*3)&7]++;
FOR0(i,K) c[SIZE]*=val[a[i]];
status[SIZE]=st;
hash[st]=SIZE++;
return;
}
int temp=-1,i;
FOR0(i,dep) upMax(temp,st>>(i*3)&7);
for(i=0;i<=temp+1;i++)
{
DFS(dep+1,st<<3|i);
}
}
int find(int x)
{
if(S[x]!=x) S[x]=find(S[x]);
return S[x];
}
int cal()
{
int visit[N]={0},tot=0,st=0,i,j;
for(i=K-1;i>=0;i--) if(!visit[i])
{
visit[i]=1;
st|=tot<<(i*3);
for(j=i-1;j>=0;j--) if(find(i+1)==find(j+1))
{
visit[j]=1,st|=tot<<(j*3);
}
tot++;
}
return hash[st];
}
void deal(int s,int mask)
{
int i,j;
for(i=0;i<=K;i++) S[i]=i;
for(i=0;i<K;i++) for(j=i+1;j<K;j++)
{
if((status[s]>>(i*3)&7)==(status[s]>>(j*3)&7))
{
int px=find(i);
int py=find(j);
if(px!=py) S[px]=py;
}
}
for(i=0;i<K;i++) if(mask&(1<<i))
{
int px=find(i);
int py=find(K);
if(px==py) return; //保证无环存在
S[px]=py;
}
for(i=1;i<=K;i++) if(find(i)==find(0)) break;
if(i>K) return; //保证连通性
a.a[s][cal()]++;
}
int main()
{
while(scanf("%d%lld",&K,&n)!=-1)
{
a.init(0);
SIZE=0;
DFS(0,0);
int i,j;
FOR0(i,SIZE) FOR0(j,1<<K) deal(i,j);
a=a.pow(n-K);
i64 ans=0;
FOR0(i,SIZE) (ans+=c[i]*a.a[i][0])%=mod;
printf("%lld\n",ans);
}
}
BZOJ 1494 生成树计数(生成树计数-矩阵)的更多相关文章
- bzoj 2111: [ZJOI2010]Perm 排列计数 (dp+卢卡斯定理)
bzoj 2111: [ZJOI2010]Perm 排列计数 1 ≤ N ≤ 10^6, P≤ 10^9 题意:求1~N的排列有多少种小根堆 1: #include<cstdio> 2: ...
- bzoj 4031: 小Z的房间 矩阵树定理
bzoj 4031: 小Z的房间 矩阵树定理 题目: 你突然有了一个大房子,房子里面有一些房间.事实上,你的房子可以看做是一个包含n*m个格子的格状矩形,每个格子是一个房间或者是一个柱子.在一开始的时 ...
- bzoj 1494 生成树计数
坑了好多天的题,终于补上了 首先发现 \(i\) 这个点和 \(i-k\) 之前的点没有边,所以 \(i-k\) 之前的点肯定联通,只要处理中间 \(k\) 个点的联通状态就好了.我们用最小表示法,\ ...
- 【BZOJ 1494】【NOI 2007】生成树计数
http://www.lydsy.com/JudgeOnline/problem.php?id=1494 这道题..因为k很小,而且我们只关心连续的k个节点的连通性,所以把连续的k个点轮廓线上的连通性 ...
- 生成树的计数 Matrix-Tree(矩阵树)定理
信息学竞赛中,有关生成树的最优化问题如最小生成树等是我们经常遇到的,而对生成树的计数及其相关问题则少有涉及.事实上,生成树的计数是十分有意义的,在许多方面都有着广泛的应用.本文从一道信息学竞赛中出现的 ...
- HDU 5304(Eastest Magical Day Seep Group's Summer-环加外向树生成树计数)[Template:Kirchhoff矩阵]
Eastest Magical Day Seep Group's Summer Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 655 ...
- 【BZOJ 4180】 4180: 字符串计数 (SAM+二分+矩阵乘法)
4180: 字符串计数 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 164 Solved: 75 Description SD有一名神犇叫做Oxe ...
- 【BZOJ 1016】 1016: [JSOI2008]最小生成树计数 (DFS|矩阵树定理)
1016: [JSOI2008]最小生成树计数 Description 现在给出了一个简单无向加权图.你不满足于求出这个图的最小生成树,而希望知道这个图中有多少个不同的最小生成树.(如果两颗最小生成树 ...
- [BZOJ 4818/LuoguP3702][SDOI2017] 序列计数 (矩阵加速DP)
题面: 传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=4818 Solution 看到这道题,我们不妨先考虑一下20分怎么搞 想到暴力,本蒟 ...
随机推荐
- UVA 10078 The Art Gallery
Problem: Century Arts has hundreds of art galleries scattered all around the country and you are hir ...
- 【BZOJ】【1037】【ZJOI2008】生日聚会party
DP orz iwtwiioi 这种题居然是DP……原来统计方案数是可以用动态规划来做的啊= =用一些变量来维护一些信息,保证方案可行性/合法性 人太弱实在是有些忧伤…… /************* ...
- 【BZOJ】【1021】【SHOI2008】Dept循环的债务
DP 去膜拜题解了>_>玛雅原来是动规…… 让我先理解一下为什么要用动规:这个题根据钱数推方案其实是无从下手的……(线性规划?……事实证明我想多了) 啦-我们先来看个超级简化版的问题:怎么 ...
- 【BZOJ】【3831】【POI2014】Little Bird
DP/单调队列优化 水题水题水题水题 单调队列优化的线性dp…… WA了8次QAQ,就因为我写队列是[l,r),但是实际操作取队尾元素的时候忘记了……不怎么从队尾取元素嘛……平时都是直接往进放的……还 ...
- Codeforces Round #204 (Div. 2)->B. Jeff and Periods
B. Jeff and Periods time limit per test 1 second memory limit per test 256 megabytes input standard ...
- C#单链表(数据结构)
学习单链表的源码项目:http://files.cnblogs.com/xmfdsh/CSharp%E5%8D%95%E9%93%BE%E8%A1%A8.rar 链表是用一组任意的存储单元来存储线性表 ...
- vitrualbox虚拟机64位安装报错解决
1 NtCreateFile(\Device\VBoxDrvStub) failed: 0xc0000034 STATUS_OBJECT_NAME_NOT_FOUND (0 retries) 解决办法 ...
- PE文件结构
PE头 typedef struct _IMAGE_NT_HEADERS { DWORD Signature; PE头标识 为固定的ascii码 PE\\ IMAGE_FILE_HEADER File ...
- 容器字段FieldContainer
//Ext.form.FieldContainer扩展自Ext.container.Container.当需要把多个字段或组件作为一个表单项展示的时候就需要此组件 Ext.Quick ...
- 【二】php常用方法
-------------------------------数据类型------------------------------------------ 1.settype(var,type) 类 ...