polya burnside 专题
polya题目:uva 11077 Find the Permutations
uva 10294 Arif in Dhaka
LA 3641 Leonardo's Notebook
uva 11077 Find the Permutations
HOJ 2084 The Colored Cubes
HOJ 2647 Megaminx
POJ 1286 Necklace of Beads
POJ 2409 Let it Bead
TOJ 2795 The Queen's New Necklaces
HDU 1812 Count the Tetris
UVa 11255 Necklace
POJ 2154 Color
POJ 2888 Magic Bracelet
UVa 10601 Cubes
NUAA 1110
uva 10294 Arif in Dhaka(项链和手镯)
题目大意:项链和手镯都是由若干珠子穿成的环形首饰,区别在于手镯可以翻转,但项链不可以。输入整数n和t,输出用t种颜色的n颗珠子(每种颜色的珠子个数无限制,但珠子总数必须是n)能制作成的项链和手镯个数。
分析:一共有两种置换,即旋转和翻转,其中项链只有第一种置换,而手镯有两种。
旋转:如果逆时针旋转i颗珠子的间距,则珠子0、i、2i、....构成一个循环。这个循环有n/gcd(i,n)个元素。根据对称性所有循环的长度均相同,因此一共有gcd(i,n)个循环。这些置换的不动点总数a=Σtgcd(i,n) ,(0<i<n)。
翻转:需要分两种情况讨论。当n为奇数时,对称轴有n条,每条对称轴形成(n-1)/2个长度为2的循环和一个长度为1的循环,即(n+1)/2个循环。这些置换不动点总数为b=nt(n+1)/2 。当n为偶数时,有两种对称轴。穿过珠子的对称轴有n/2条,各形成n/2-1个长度为2的循环和2个长度为1的循环;不穿过珠子的对称轴有n/2条,各形成n/2个长度为2的循环。这些置换不动点的总数b=n/2(tn/2+1+tn/2)。
#include<iostream>
using namespace std; typedef long long LL;
LL power[]; int gcd(int a,int b)
{
return b?gcd(b,a%b):a;
} int main()
{
int n,i,t;
LL a,b;
power[]=;
while(cin>>n>>t)
{
for(i=;i<=n;i++) power[i]=power[i-]*t;
a=;
for(i=;i<n;i++)
a+=power[gcd(i,n)];
if(n%) b=n*power[(n+)/];
else b=n/*(power[n/+]+power[n/]);
cout<<a/n<<" "<<(a+b)//n<<endl;
}
return ;
}
LA 3641 Leonard's Notebook
题目大意:给出26个大写字母的置换B,问是否存在一个置换A,使得A^2=B。
分析:置换A与A^2有着怎样的关系。先把A做循环分解,比如A=(a1 a2 a3)(b1 b2 b3 b4)。那么
A^2=(a1 a2 a3)(b1 b2 b3 b4)(a1 a2 a3)(b1 b2 b3 b4)
注意不相交的循环的乘法满足交换率
A^2=(a1 a2 a3)(a1 a2 a3)(b1 b2 b3 b4)(b1 b2 b3 b4)
根据置换乘法的结合律:
1 2 3 * 1 2 3 = 1 2 3
2 3 1 2 3 1 3 1 2 (a1 a2 a3)(a1 a2 a3)=(a1 a3 a2)
1 2 3 4 * 1 2 3 4 = 1 2 3 4
2 3 4 1 2 3 4 1 3 4 1 2 (b1 b2 b3 b4)(b1 b2 b3 b4)=(b1 b3)(b2 b4)
不难得出如下规律,两个长度为n的相同循环相乘,当n为奇数时结果也是一个长度为n的循环;当n为偶数时分裂为两个长度为n/2的循环。相反,对于任意一个长度n为奇数的循环B,都能找到一个长度为n的循环使得A^2=B;对于任意两个长度n的且不相交循环B和C,都能找到一个长度为2n的循环A使得A^2=BC。
反过来说。对B中的循环。
长度n为奇数的循环可以是A中一个长度为n的循环产生的如(2 3 1)(2 3 1)=(1 3 2),也可以与B中另一个长度n的循环是A中一个长度为2n的循环产生的如(2 3 4 5 6 1)(2 3 4 5 6 1)=(1 3 5)(2 4 6)
长度n为偶数的循环只能是与B中另一个长度n的循环是A中一个长度为2n的循环产生的如(2 3 4 1)(2 3 4 1)=(1 3)(2 4)。
所以对于B中任意偶数长度的循环,这个长度的循环的个数必须是偶数才能配对。所以只要能配对成功,一定有解,否则无解。
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std; int main()
{
int t,i,j,f[],n,flag;
char s[];
bool vis[];
scanf("%d",&t);
while(t--)
{
scanf("%s",s);
memset(vis,false,sizeof(vis));
memset(f,,sizeof(f));
for(i=;i<;i++)
{
if(!vis[i])
{
j=i;n=;
do{
vis[j]=true;
j=s[j]-'A';
n++;
}while(i!=j);
f[n]++;//长度为n的循环个数+1
}
}
flag=;
for(i=;i<=;i+=)//长度n为偶数的循环能否配对
{
if(f[i]%)
{
flag=;break;
}
}
if(flag) printf("Yes\n");
else printf("No\n");
}
return ;
}
uva 11077 Find the Permutations
题目大意:给出1-n的一个排列,可以通过一系列的交换变成{1,2,3,....,n}。比如{2,1,4,3}需要两次交换(1和2,3和4),{4,2,3,1}只需交换一次(1和4),{2,3,4,1}需要三次,而{1,2,3,4}本身一次都不需要。给定n和k,统计有多少个排列至少需要交换k次才能变成{1,2,3....n}。
分析:不难发现单个元素不需要交换,2个元素要交换一次,3个元素要交换两次,.....,c个元素的循环要交换c-1次。这样,如果排列p的循环节为x个,则总的交换次数为n-x次。有了上述结论,就不难进行递推了。设f(i,j)表示满足“至少需要交换j次才能变成{1,2,3,...,i}”的排列个数,则f(i,j)=f(i-1,j)+f(i-1,j-1)*(i-1),因为元素i要么自己形成一个循环,要么加入前面任意一个循环的任意一个位置(i-1个)。边界f(1,0)=1,其他f(1,j)=0。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std; typedef unsigned long long LL;
LL f[][]; int main()
{
int i,j;
memset(f,,sizeof(f));
f[][]=;
for(i=;i<;i++)
{
for(j=;j<i;j++)
{
f[i][j]=f[i-][j];
if(j) f[i][j]+=f[i-][j-]*(i-);
}
}
while(cin>>i>>j,i+j) printf("%llu\n",f[i][j]);
return ;
}
polya burnside 专题的更多相关文章
- polya/burnside 学习
参考链接: http://www.cnblogs.com/hankers/archive/2012/08/03/2622231.html http://blog.csdn.net/raalghul/a ...
- 【BZOJ】1004: [HNOI2008]Cards(置换群+polya+burnside)
http://www.lydsy.com/JudgeOnline/problem.php?id=1004 学习了下polya计数和burnside引理,最好的资料就是:<Pólya 计数法的应用 ...
- [POJ 2888]Magic Bracelet[Polya Burnside 置换 矩阵]
也许更好的阅读体验 \(\mathcal{Description}\) 大意:给一条长度为\(n\)的项链,有\(m\)种颜色,另有\(k\)条限制,每条限制为不允许\(x,y\)颜色连在一起.要求有 ...
- 博客索引and题目列表
目录 笔记整理 计划 要学的东西 缺省源 要做的题 搜索 高斯消元 矩阵 排列组合 2019.7.9 2019.7.10 kmp ac自动机 2019.7.11 2019.7.15 笔记整理 1.同余 ...
- POJ burnside&&polya整理练习
POJ 2409 Let it Bead 这题就是polya公式的直接套用,唯一麻烦的是置换群的种类数,由于可以翻转,所以除了要加上pow(c,gcd(s,i))这些平面旋转的置换群,还要加上翻转的. ...
- Burnside引理和Polya定理之间的联系
最近,研究了两天的Burnside引理和Polya定理之间的联系,百思不得其解,然后直到遇到下面的问题: 对颜色限制的染色 例:对正五边形的三个顶点着红色,对其余的两个顶点着蓝色,问有多少种非等价的着 ...
- Burnside引理与Polya定理
感觉这两个东西好鬼畜= = ,考场上出了肯定不会qwq.不过还是学一下吧用来装逼也是极好的 群的定义 与下文知识无关.. 给出一个集合$G = \{a, b, c, \dots \}$和集合上的二元运 ...
- Burnside引理与Polya定理 学习笔记
原文链接www.cnblogs.com/zhouzhendong/p/Burnside-Polya.html 问题模型 有一个长度为 $n$ 的序列,序列中的每一个元素有 $m$ 种取值. 如果两个序 ...
- burnside+polya 整理
先定义几个含义和符号:起始状态/方法/位置/元素/:以染色为例,起始状态是所有的染色方案,方法是以起始状态所有染色方案为基准转变为新的染色情景的操作(如旋转),位置则必须是没有任何染色效果的抽象空间, ...
随机推荐
- 洛谷 P1901 发射站
题目描述 某地有 N 个能量发射站排成一行,每个发射站 i 都有不相同的高度 Hi,并能向两边(当 然两端的只能向一边)同时发射能量值为 Vi 的能量,并且发出的能量只被两边最近的且比 它高的发射站接 ...
- 将从SQL2008 r2里备份的数据库还原到SQL2008中
从标题可以看出这是未解决上一篇遗留问题写的,现在我也不知道这个可不可以成功,方法似乎查到了一种,具体怎样还不清楚:而且,我想说的是“我踩雷了”. 这篇的主角是“Database Publishing ...
- Mybatis-Generator逆向生成Po,Mapper,XMLMAPPER(idea)
前文有一篇手工生成的说明,地址: http://www.cnblogs.com/xiaolive/p/4874605.html, 现在这个补充一下在idea里面的自动版本的数据库逆向生成工具: 一.g ...
- QT 图形视图框架
https://blog.csdn.net/qq769651718/article/details/79357936 使用QPushButton.QLabel.QCheckBox等构成GUI的控件或自 ...
- Hopfield 网络(下)
讲的什么 这部分主要讲离散的 Hopfield 网络权值的计算方法,以及网络记忆容量.主要参考了网上搜到的一些相关 PPT. DHNN 的训练方法 常见的学习方法中有海布法,还有 \(\delta ...
- linux下怎么修改mysql的字符集编码
安装完的MySQL的默认字符集为 latin1 ,为了要将其字符集改为用户所需要的(比如utf8),就必须改其相关的配置文件:由于linux下MySQL的默认安装目录分布在不同的文件下:不像windo ...
- springmvc导出excel(POI)
/** * 导出excel表格 */ @RequestMapping(value = "/doExportData", method = {RequestMethod.POST, ...
- What is the difference between try/except and assert?
assert only check if a condition is true or not and throw an exception. A try/except block can run a ...
- Luogu P4231 三步必杀 (差分)
目录 题目 题解 题目 题目链接 题目背景 (三)旧都 离开狭窄的洞穴,眼前豁然开朗. 天空飘着不寻常的雪花. 一反之前的幽闭,现在面对的,是繁华的街市,可以听见酒碗碰撞的声音. 这是由被人们厌恶的鬼 ...
- docker系列之镜像服务器
docker 的镜像服务器 docker-registry 是 docker 项目的组成部分. 前面在谈 docker 的命令时, 它的 pull/push 命令就是和镜像服务器打交道. 并且, do ...