对Polya定理的个人认识

    我们先来看一道经典题目:

    He's Circles(SGU 294)

        有一个长度为N的环,上面写着“X”和“E”,问本质不同的环有多少个(不能旋转重复就称之为本质不同)

输入样例:4

输出样例:6

那么要怎么办呢?暴力显然暴不出来……

我们可以考虑使用置换群。

我们有两种算法:

①Burnside引理:

答案直接为1/|G|*(D(a1)+D(a2)+D(a3)+……+D(as))

其中D(ak)为在进行置换群置换操作ak下不变的元素的个数。

在N=4下一共有四个置换群:

(1 2 3 4    (1 2 3 4    (1 2 3 4    (1 2 3 4

1 2 3 4)    2 3 4 1)    3 4 1 2)    4 1 2 3)

那么显然在置换a1下都不变,那么D(a1)=16 (4*4)

EEEE和XXXX在置换a2下都不变,所以D(a2)=2

XXXX和EEEE还有XEXE以及EXEX在置换a3下都不变,所以D(a3)=4

XXXX和EEEE在置换a4的情况下都不变,D(a4)=2

最后根据公式计算出1/|4|*(16+2+4+2)=6(种)

 

        ②Polya定理

             回顾上面的Burnside算法,是否感觉D不太好实现呢?

那么我们就可以用一种更容易理解、适应力强、时间复杂度低、编程复杂度低的方法就是群论的最厉害的Polya定理

其实Polya定理与Burnside引理本质上的区别并不是很大,只不过入手问题的角度不一样。

我们可以发现,一个循环节之间的“不变元素”可以互相交换从而不影响整体,所以我们可以设Ci为置换群i的循环节个数。

例如(1 2 3 4 5

3 5 1 4 2)

的循环节就为:1和3循环1->3->1……

2和5循环2->5->2……

4和它自身循环4->4->4……

那么循环节数就为3

再回来看现在这个题目,我们可以抽象地把Ci替换掉Di

那么Di=p^C(i) (p为总共的字母数)

相同循环节中的元素可以互相置换,所以Di=p^C(i)

polya公式为1/|G|(p^C(1)+p^C(2)+……+p^C(s))

以4为例,则1/|G|=1/4

C(1):循环节为(1)(2)(3)(4),所以C(1)=4

C(2):循环节为(4 3 2 1),所以C(2)=1

C(3):循环节为(1 3)(2 4),所以C(3)=2

C(4):循环节为(1 2 3 4),所以C(4)=1

那么答案就为1/4(2^4+2^1+2^2+2^1)=6

这里的C相对于上面的D来说要简单,记得XJR学长给我讲过环的判定,直接任选一个没有选过的点,从这个点开始映射,走过的点标上1,等到再走到标上1时,结束,统计数加1

void search(int M){
	int i=M;//一开始从这里开始
	while(!flag[b[i]]){//如果它的映射没被访问过,那么说明它还没有构成环
		i=b[i];//继续映射
		flag[i]=1;//标记已访问
	}
	return ;//返回
}
int C(){
	int tmp=0;
	for(int i=1;i<=N;i++) if(!flag[i]) flag[i]=1,search(i),tmp++;//环数加1
	return tmp;//返回循环节数
}

  那么我们再加上一个快速幂,就可以进一步优化。

【群论】polya定理的更多相关文章

  1. UVA10294 Arif in Dhaka (群论,Polya定理)

    UVA10294 Arif in Dhaka (群论,Polya定理) 题意 : 给你一个长为\(n\)的项链和手镯,每个珠子有\(m\)种颜色. 两个手镯定义为相同,即它们通过翻转和旋转得到一样的手 ...

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

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

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

    [BZOJ1488][HNOI2009]图的同构(Burside引理,Polya定理) 题面 BZOJ 洛谷 题解 求本质不同的方案数,很明显就是群论这套理论了. 置换一共有\(n!\)个,考虑如何对 ...

  4. 群论&Polya计数

    群论&Polya计数 其实在我听课的过程中,我发现针对于学习OI中的群并没有什么过多必要向内学习... 群 以后会补的. 就是\(QQ\)群. 置换 置换就是一个... \[ \begin{m ...

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

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

  6. 【转】Polya定理

    转自:http://endlesscount.blog.163.com/blog/static/82119787201221324524202/ Polya定理 首先记Sn为有前n个正整数组成的集合, ...

  7. [wikioi2926][AHOI2002]黑白瓷砖(Polya定理)

    小可可在课余的时候受美术老师的委派从事一项漆绘瓷砖的任务.首先把n(n+1)/2块正六边形瓷砖拼成三角形的形状,右图给出了n=3时拼成的“瓷砖三角形”.然后把每一块瓷砖漆成纯白色或者纯黑色,而且每块瓷 ...

  8. HDU 3923 Invoker(polya定理+逆元)

    Invoker Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 122768/62768 K (Java/Others)Total Su ...

  9. Polya定理

    http://www.cnblogs.com/wenruo/p/5304698.html 先看 Polya定理,Burnside引理回忆一下基础知识.总结的很棒. 一个置换就是集合到自身的一个双射,置 ...

随机推荐

  1. 给自定义cell赋值代码

    // //  ViewController.m //  11 - 投资管理 - 李洪强 // //  Created by vic fan on 16/4/8. //  Copyright © 201 ...

  2. 【android】新手容易遇到的[error: Error retrieving parent for item: No resource found that matches the given name 'Theme.AppCompat.Light'.]Theme出错的问题

    一.概述 近期刚接手了一个项目,开发工具为eclipse,由于版本较低,且考虑到如果转android studio项目的话,会其他人的维护带来困难,所以想着还是维护项目原来的开发环境吧. 但是导入项目 ...

  3. Quartz.net 的简单使用,创建定时任务

    ISchedulerFactory sf = new StdSchedulerFactory(); sched = sf.GetScheduler(); JobDetail job = new Job ...

  4. javascript中判断对象类型

    <script type="text/javascript"> //判别一个对象属性在不在某个对象中 //in 是用于查找某个属性是否存在于对象中,它会把对象 //里面 ...

  5. js 日期

    let date = new Date(); let year = date.getFullYear(); let money = money = date.getMonth() + 1; let d ...

  6. 20145334实验三《敏捷开发与XP实践》

    实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 了解设计模式 实验步骤 1.敏捷开发与XP 敏捷开发(Agile Dev ...

  7. Android课程---String、StringBuffer 、StringBuilder 的区别(转)

    String 字符串常量 StringBuffer 字符串变量(线程安全) StringBuilder 字符串变量(非线程安全)  简要的说, String 类型和 StringBuffer 类型的主 ...

  8. IOS第11天(2:UIPickerView自定义国旗选择)

    国旗选择 #import "HMViewController.h" #import "HMFlag.h" #import "HMFlagView.h& ...

  9. Sharepoint 2013 网站集的删除与还原

    一.可以通过三种方法删除网站集: 1.打开Sharepoint 2013 管理页面首页 ---> 单击‘应用程序管理(Application Management)’并进入该页面 ---> ...

  10. MySQL 启动时禁用了 InnoDB 引擎的解决方法

    今天在从本地数据库复制表数据到虚拟机 CentOS 6.6 上的数据库时,得到提示: Unknown table engine 'InnoDB' 于是在服务器 MySQL 中查看了引擎: mysql& ...