【BZOJ1488】[HNOI2009]图的同构(Burside引理,Polya定理)

题面

BZOJ

洛谷

题解

求本质不同的方案数,很明显就是群论这套理论了。

置换一共有\(n!\)个,考虑如何对于任意一个置换求不动点数量。

首先边存在或者不存在太麻烦了,我们假装所有边都已经存在,出现过的边和不存在的边用两种不同的颜色染色即可。这样子我们就假装所有的边都出现了,也就是一个完全图。

显然循环是对于点而论的,但是这题同构是对于边而论的。那么我们对于一个点的循环,考虑它的两个顶点。这两个顶点只有两种不同情况,要么在同一个循环内,要么不在同一个循环内。考虑所有在同一个循环中的\(n\)点形成的完全图,那么它的边构成了\(n/2\)个循环,感性理解就是,我们把\(n\)个点拉成一排,把相邻距离为定值的点连上边,显然这样子会构成一个环,因为这个距离的定值\(d\)和\(n-d\)是等价的,所以边构成了\(n/2\)个循环。

考虑两个顶点不在一个循环内,那么构成循环必定是在一个点集中选择一条边连向另外一个点集,再从另外一个点集中选一条边连回来,我们把点集看成两个环,那么每次可以把环上所有的点旋转一下,那么旋转\(lcm\)次之后就转回来了,意味着这\(lcm\)条边必须相同,即构成一个循环,那么边的循环的个数就是\(gcd\)了。

假设有边的置换,我们很容易知道不动点的数量就是\(2^m\),其中\(m\)是边置换的数量,显然你的个置换中的边的颜色都是相同的。

这样一来,我们就把点置换转换为边置换了,这样就可以方便的计算了。

\(60\)的拆分数大概是百万级别的,我们似乎是可以爆搜拆分数计算答案的。

那么考虑一个拆分数实际上对应的方案数,这个排列组合计算一下就好了。

我们假设有\(k\)个循环,每个的大小分别是\(a_1,a_2,...\),每个大小的置换个数是\(num_1,num_2...\)

那么这种情况的贡献就是\(\frac{n!}{(\prod a_i!)*(\prod num_i!)}\),原因就是,\(n!\)是所有方案,然后对于每个置换内,显然环的位置不影响,出去等价的环,然后对于每个等大小的置换,显然位置是可以交换的,那么除去阶乘的排列的影响。

好了,这样子大概可以算完所有置换的不动点数量,然后除掉一个置换总数就对了,显然置换总数是\(n!\)。

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
#define MOD 997
#define MAX 75
int n,ans,jc[MOD],inv[MOD],jv[MOD];
int g[MAX][MAX],a[MAX],b[MAX],bin[MAX*MAX];
void calc()
{
int ret=jc[n],tot=0,sum=0;
for(int i=1;i<=n;++i)
{
ret=ret*jv[a[i]]%MOD;
for(int j=1;j<=a[i];++j)
ret=ret*inv[i]%MOD,b[++tot]=i;
}
for(int i=1;i<=tot;++i)sum+=b[i]/2;
for(int i=1;i<=tot;++i)
for(int j=i+1;j<=tot;++j)
sum+=g[b[i]][b[j]];
ret=ret*bin[sum]%MOD;
ans=(ans+ret)%MOD;
}
void dfs(int x,int sum)
{
if(x==1){a[x]=n-sum;calc();return;}
for(int i=0;sum+i*x<=n;++i)
a[x]=i,dfs(x-1,sum+i*x);
}
int main()
{
scanf("%d",&n);
jc[0]=jv[0]=inv[0]=inv[1]=bin[0]=1;
for(int i=2;i<MOD;++i)inv[i]=inv[MOD%i]*(MOD-MOD/i)%MOD;
for(int i=1;i<MOD;++i)jc[i]=jc[i-1]*i%MOD;
for(int i=1;i<MOD;++i)jv[i]=jv[i-1]*inv[i]%MOD;
for(int i=1;i<MAX*MAX;++i)bin[i]=bin[i-1]*2%MOD;
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j)
g[i][j]=__gcd(i,j);
dfs(n,0);ans=ans*jv[n]%MOD;
printf("%d\n",ans);return 0;
}

【BZOJ1488】[HNOI2009]图的同构(Burside引理,Polya定理)的更多相关文章

  1. bzoj1488 [HNOI2009]图的同构 Burnside 引理

    题目传送门 bzoj1488 - [HNOI2009]图的同构 bzoj1815 - [Shoi2006]color 有色图(双倍经验) 题解 暴力 由于在做题之前已经被告知是 Burnside 引理 ...

  2. burnside引理&polya定理

    burnside引理&polya定理 参考资料: <polya计数法的应用>--陈瑜希 黄学长 置换: 置换即是将n个元素的染色进行交换,产生一个新的染色方案. 群: 一个元素的集 ...

  3. [bzoj1488][HNOI2009]图的同构——Polya定理

    题目大意 求两两互不同构的含n个点的简单图有多少种. 简单图是关联一对顶点的无向边不多于一条的不含自环的图. a图与b图被认为是同构的是指a图的顶点经过一定的重新标号以后,a图的顶点集和边集能完全与b ...

  4. bzoj1488[HNOI2009]图的同构

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1488 1488: [HNOI2009]图的同构 Time Limit: 10 Sec  M ...

  5. 【uva 10294】 Arif in Dhaka (First Love Part 2) (置换,burnside引理|polya定理)

    题目来源:UVa 10294 Arif in Dhaka (First Love Part 2) 题意:n颗珠子t种颜色 求有多少种项链和手镯 项链不可以翻转 手镯可以翻转 [分析] 要开始学置换了. ...

  6. 等价类计数:Burnside引理 & Polya定理

    提示: 本文并非严谨的数学分析,有很多地方是自己瞎口胡的,仅供参考.有错误请不吝指出 :p 1. 群 1.1 群的概念 群 \((S,\circ)\) 是一个元素集合 \(S\) 和一种二元运算 $ ...

  7. hdu 5868 2016 ACM/ICPC Asia Regional Dalian Online 1001 (burnside引理 polya定理)

    Different Circle Permutation Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 262144/262144 K ...

  8. BZOJ 1488 Luogu P4727 [HNOI2009]图的同构 (Burnside引理、组合计数)

    题目链接 (Luogu) https://www.luogu.org/problem/P4727 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.ph ...

  9. [BZOJ1815&BZOJ1488]有色图/图的同构(Polya定理)

    由于有很多本质相同的重复置换,我们先枚举各种长度的点循环分别有多少个,这个暴搜的复杂度不大,n=53时也只有3e5左右.对于每种搜索方案可以轻易求出它所代表的置换具体有多少个. 但我们搜索的是点置换组 ...

随机推荐

  1. 快速在Ubuntu安装PHP网站

    快速安装使用的是tasksel,tasksel是Debian / Ubuntu的工具,安装多个相关软件包作为一个协调的“任务”到你的系统.这个lamp-server^跟taskel这个程序有关.下面是 ...

  2. python_分布式进程中遇到的问题

    看文档学习分布式进程中遇到了一下问题,文档里面例题是python2.X,我用的python3.x,就出现了一下莫名奇妙的问题,最终版代码先呈上: taskManager.py # coding:utf ...

  3. 20155229《网络对抗技术》Exp6:信息收集与漏洞扫描

    实验内容 (1)各种搜索技巧的应用 (2)DNS IP注册信息的查询 (3)基本的扫描技术:主机发现.端口扫描.OS及服务版本探测.具体服务的查点 (4)漏洞扫描:会扫,会看报告,会查漏洞说明,会修补 ...

  4. 20155233 《网络对抗》 Exp5 MSF基础应用

    主动攻击:ms08_067漏洞攻击 启用msf终端msfconsole然后使用search命令搜索该漏洞对应的模块:search ms08_067 选择输入use exploit/windows/sm ...

  5. CISCN 应用环境相关指令备忘录

    1 - 关于Python环境的 使用Anaconda2管理Python环境 1.1 - 安装 官网下载安装包下载. 1.2 - 创建Python环境 localhost:template mac$ c ...

  6. POJ2531&&1416&&2676&&1129

    搜索专题的最后一块了,也告别了这些老的东西了 接下来就是些全新的内容了啊! 这次的标签是简单搜索技巧和剪枝,也就是优化爆搜 当然,像Dancing links这样的玄学操作还是没有的 2531 题意: ...

  7. Luogu P1983 车站分级

    (一周没写过随笔了) 这道题有坑! 看到题目,发现这么明显(??)的要求顺序,还有什么想法,拓扑! 将每条路范围内等级大于等于它的点(不能重复(坑点1))和它连一条边,注意起点终点都要有(坑点2),然 ...

  8. pygame 入门实例

    本文基于win7(64) + py3.5(64)环境. 本文是这里的一篇学习笔记.加入了自己的理解. 本文最终目的是实现一个飞机躲避导弹的游戏. 1.核心概念 pygame 的核心概念有: Surfa ...

  9. SSIS 更新变量

    在Package中声明一个variable,在package运行的过程中,SSIS如何update Variable? 第一种方法:使用 Script Task 来更新Variable的值 1,创建一 ...

  10. BugkuCTF 文件上传测试

    前言 写了这么久的web题,算是把它基础部分都刷完了一遍,以下的几天将持续更新BugkuCTF WEB部分的题解,为了不影响阅读,所以每道题的题解都以单独一篇文章的形式发表,感谢大家一直以来的支持和理 ...