在介绍\(Polya\) 定理前,先来介绍一下群论(大概了解一下就好):

群是满足下列要求的集合:

  1. 封闭性:即有一个操作使对于这个集合中每个元素操作完都使这个集合中的元素
  2. 结合律:即对于上面那个操作有结合律
  3. 单位元:对于\(a * e = a\)则称\(e\)是集合\(A\)对于操作\(*\)(并不一定是相乘)的逆元
  4. 逆元:即有\(a * b = b * a = e\)对于元素\(a\)有逆元

    置换群:

    考虑这样的一个全置换集合,可以验证该集合为群。(置换不懂的话建议右转百度,这里不细说)

接下来介绍\(Burnside\)定理

对于一类染色问题,并统计在一些操作下的本质不同方案数有这样一个公式:

我们把所有的操作(类似于顺时针旋转,对称等等)写成一个置换群

则有答案为:

\(ans = \frac{1}{cnt}\sum_{f \in G}p(f)\)

其中\(p(f)\)指的是在该置换下不变的染色方案数。

举例有:

一个大小\(5\)的环,顺时针旋转了\(144\)度的置换为:

\(
\begin{pmatrix}
1&2&3&4&5\\
4&5&1&2&3
\end{pmatrix}
\)

以两种颜色染色则有:

\(
\begin{pmatrix}
1&1&1&1&1
\end{pmatrix}
\)

\(
\begin{pmatrix}
0&0&0&0&0
\end{pmatrix}
\)

两种方案满足对该置换不动。

接下来介绍\(Polya\)定理

考虑把置换写成循环的形式

\(
\begin{pmatrix}
1&2&3&4\\
1&2&3&4
\end{pmatrix}
\)

写作:\((1)(2)(3)(4)\)

\(
\begin{pmatrix}
1&2&3&4\\
3&4&1&2
\end{pmatrix}
\)

写作:\((1\ 3)(2\ 4)\)

则有\(Polya\)定理\(ans = \frac{1}{cnt}\sum_{f \in G}k^{m(f)}\)

\(k\)为染色数,\(m(f)\)为该置换拆解成的循环数。

【模板】Pólya 定理

考虑写出置换后,易证得顺时针旋转\(k\)次的置换的循环为\(gcd(n,k)\)

则有\(ans = \frac{1}{n}\sum_i^n n^{gcd(n,i)}\)

这样复杂度不在承受范围内,考虑枚举\(gcd(n,i)\)

\(ans = \frac{1}{n}\sum_{L|n} n^{L} * \varphi(\frac{n}{L})\)

这样就能在根号里做出答案了。

【模板】Pólya 定理
#include<iostream>
#include<cstdio>
#include<cmath>
#define ll long long
#define mod 1000000007 ll T,n; inline ll pow(ll a,ll b){
ll ans = 1;
while(b){
if(b & 1) ans = 1ll * ans * a % mod;
a = a * a % mod;
b >>= 1;
}
return ans % mod;
} inline ll phi(int now){
int ans = now;
for(int i = 2;i * i <= now;++i){
if(now % i)continue;
ans = ans - ans / i;
while(now % i == 0)
now /= i;
}
if(now != 1)
ans = ans - ans / now;
return ans % mod;
} inline ll get(int now){ll ans = phi(n / now) * pow(n,now) % mod;} int main(){
scanf("%lld",&T);
while(T -- ){
scanf("%lld",&n);
ll ans = 0;
for(int i = 1;i * i <= n;++i){
if(n % i == 0){
ans = (ans + get(i)) % mod;
if(n / i != i)
ans = (ans + get(n / i)) % mod;
}
}
std::cout<<ans * pow(n,mod - 2) % mod<<std::endl;
}
}

Pólya 定理学习笔记的更多相关文章

  1. Burnside引理与Polya定理 学习笔记

    原文链接www.cnblogs.com/zhouzhendong/p/Burnside-Polya.html 问题模型 有一个长度为 $n$ 的序列,序列中的每一个元素有 $m$ 种取值. 如果两个序 ...

  2. Lucas定理学习笔记

    从这里开始 一个有趣的问题 扩展Lucas算法 一个有趣的问题 题目大意 给定$n, m, p$,求$C_{n}^{m}$除以$p$后的余数. Subtask#1  $0\leqslant m\leq ...

  3. Master定理学习笔记

    前言 \(Master\)定理,又称主定理,用于程序的时间复杂度计算,核心思想是分治,近几年\(Noip\)常考时间复杂度的题目,都需要主定理进行运算. 前置 我们常见的程序时间复杂度有: \(O(n ...

  4. Matrix_tree Theorem 矩阵树定理学习笔记

    Matrix_tree Theorem: 给定一个无向图, 定义矩阵A A[i][j] = - (<i, j>之间的边数) A[i][i] = 点i的度数 其生成树的个数等于 A的任意n ...

  5. 生成树计数 Matrix-Tree 定理 学习笔记

    一直都知道要用Matrix-Tree定理来解决生成树计数问题,但是拖到今天才来学.博主数学不好也只能跟着各位大佬博客学一下它的应用以及会做题,证明实在是不会. 推荐博客: https://www.cn ...

  6. Ploya定理学习笔记

    由于自己的作息极其不规律导致比赛被打爆了 但是有的时候状态其实还行. 关于Ploya定理其实特别有意思 这里粘一个[dalao的blog](https://blog.csdn.net/lyc16355 ...

  7. Polya 定理 学习笔记

    群 群的定义 我们定义,对于一个集合 \(G\) 以及二元运算 \(\times\),如果满足以下四种性质,那我们就称 \((G,\times)\) 为一个群. 1. 封闭性 对于 \(a\in G, ...

  8. 矩阵树定理&BEST定理学习笔记

    终于学到这个了,本来准备省选前学来着的? 前置知识:矩阵行列式 矩阵树定理 矩阵树定理说的大概就是这样一件事:对于一张无向图 \(G\),我们记 \(D\) 为其度数矩阵,满足 \(D_{i,i}=\ ...

  9. [HEOI2015]小Z的房间(矩阵树定理学习笔记)

    题目描述 你突然有了一个大房子,房子里面有一些房间.事实上,你的房子可以看做是一个包含n*m个格子的格状矩形,每个格子是一个房间或者是一个柱子.在一开始的时候,相邻的格子之间都有墙隔着. 你想要打通一 ...

随机推荐

  1. 力扣 - 剑指 Offer 39. 数组中出现次数超过一半的数字

    题目 剑指 Offer 39. 数组中出现次数超过一半的数字 思路1(排序) 因为题目说一定会存在超过数组长度一半的一个数字,所以我们将数组排序后,位于length/2位置的一定是众数 代码 clas ...

  2. 《python编程:从入门到实践》课后习题及答案

    转载: <Python编程:从入门到实践>课后习题及答案-码农之家 (xz577.com) <Python编程:从入门到实践>课后习题及答案 - 信德维拉 - 博客园 (cnb ...

  3. F1英国大奖赛-银石赛道地图及弯道

    背景 今天晚上(2020-08-02)是今年英国大奖赛的正赛.刚好了解了一下赛道地图.记录一下,明年就不用到处找了. 简介 银石赛道(Silverstone Circuit)由一个废弃的空军基地改建, ...

  4. Java:LinkedHashMap类小记

    Java:LinkedHashMap类小记 对 Java 中的 LinkedHashMap类,做一个微不足道的小小小小记 概述 public class LinkedHashMap<K,V> ...

  5. 移动端 h5 uniapp 读,写,删本地文件或sd文件

    移动端 h5 uniapp 读,写,删本地文件或sd文件 应用场景: 当我们需要做离线应用或者是加载本地文件时使用到此方法.(本篇文章给大家分享访问app私有文件目录,系统公共目录,sd外置存储的文件 ...

  6. [no_code][Beta] 中期组内总结

    $( "#cnblogs_post_body" ).catalog() 目前scrum meeting beta阶段目前共7次.在alpha阶段我们博客发布时间比较匆忙,是扣分项, ...

  7. Linux线程互斥学习笔记--详细分析

    一.互斥锁 为啥要有互斥? 多个进程/线程执行的先后顺序不确定,何时切出CPU也不确定. 多个进程/线程访问变量的动作往往不是原子的. 1. 操作步骤 (1)创建锁 // 创建互斥锁mutex pth ...

  8. 『学了就忘』Linux基础 — 6、VMware虚拟机安装Linux系统(超详细)

    目录 1.打开VMware虚拟机软件 2.选择Linux系统的ISO安装镜像 3.开启虚拟机安装系统 (1)进入Linux系统安装界面 (2)硬件检测 (3)检测光盘 (4)欢迎界面 (5)选择语言 ...

  9. 【做题记录】[NOIP2016 普及组] 魔法阵

    P2119 魔法阵 2016年普及组T4 题意: 给定一系列元素 \(\{X_i\}\) ,求满足以下不等式的每一个元素作为 \(a,b,c,d\) 的出现次数 . \[\begin{cases}X_ ...

  10. jquery正则表达式验证【是否带有小数、是否中文名称组成、是否全由8位数字组成、电话码格式、邮件地址】

    1 <form name="myform" action="" onsubmit="return fun1()"> 2 < ...