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 整理
先定义几个含义和符号:起始状态/方法/位置/元素/:以染色为例,起始状态是所有的染色方案,方法是以起始状态所有染色方案为基准转变为新的染色情景的操作(如旋转),位置则必须是没有任何染色效果的抽象空间, ...
随机推荐
- org.thymeleaf.exceptions.TemplateInputException: Error resolving template "/home/index2", template might not exist or might not be accessible by any of the configured Template Resolvers
org.thymeleaf.exceptions.TemplateInputException: Error resolving template "/home/index2", ...
- k8s 如何 Failover?
上一节我们有 3 个 nginx 副本分别运行在 k8s-node1 和 k8s-node2 上.现在模拟 k8s-node2 故障,关闭该节点. 等待一段时间,Kubernetes 会检查到 k8s ...
- python基础面试题整理---从零开始 每天十题(02)
书接上回,我们继续来说说python的面试题,我在各个网站搜集了一些,我给予你们一个推荐的答案,你们可以组织成自己的语言来说出来,让我们更好的做到面向工资编程 一.Q:说说你对zen of pytho ...
- Springboot 命令注入属性[--]&[-D]
场景 在用Jenkins,做自动化部署时,遇到一些命令问题. 需要通过命令的形式,注入些业务值. -D 系统属性注入 Java,启动jar 命令: java [ options ] -jar file ...
- SSH中的jar包讲解
我们在搭建SSH框架的时候,需要引入各自的一些jar包 首先,先来看一下我们使用的SSH的各自版本及引入的jar包. struts2.3.1.2: struts2-core-2.3.1.jar j ...
- tableview 删除cell
正如在以前的帖子说,但是我在转到故事版(StoryBoard)教程之前,我有另外一个问题来回答. 我如何从UITableView删除一行呢? 当人们构建简单的表视图引用程序后,这是另一个常见的问题 ...
- JavaScript设计模式基础之闭包(终)
对于前端程序员来说闭包还是比较难以理解的, 闭包的形成与变量的作用域以及变量的生产周期密切相关,所以要先弄懂变量的作用域和生存周期. 1.变量作用域 变量的作用域,就是指变量的有效范围,通常我们指的作 ...
- Hanoi双塔问题
题目描述: 给定A.B.C三根足够长的细柱,在A柱上放有2n个中间有孔的圆盘,共有n个不同的尺寸,每个尺寸都有两个相同的圆盘,注意这两个圆盘是不加区分的(下图为n=3的情形).现要将这些圆盘移到C柱上 ...
- [CODEVS] 3955 最长严格上升子序列(加强版)
题目描述 Description 给一个数组a1, a2 ... an,找到最长的上升降子序列ab1<ab2< .. <abk,其中b1<b2<..bk. 输出长度即可. ...
- (26)zabbix脚本报警介质自定义(钉钉)
zabbix机器人告警配置 首先在钉钉中创建一个群然后设置群机器人添加自定义机器人(webhook...) 添加后复制其中的webhook地址到报警脚本dingding.py中的webhook=... ...