zoukankan      html  css  js  c++  java
  • 【poj2409】Let it Bead Polya定理

    题目描述

    用 $c$ 种颜色去染 $r$ 个点的环,如果两个环在旋转或翻转后是相同的,则称这两个环是同构的。求不同构的环的个数。 $r·cle 32$ 。


    题解

    Polya定理

    Burnside引理:一个置换群的等价类数目等于这个置换群中所有置换的不动点数目的平均值;
    Polya定理:设有限群G有 $m$ 个置换,第 $i$ 个置换有 $a_i$ 个循环,现在要将所有的点染成 $c$ 种颜色,那么染色后群G的等价类数目为:$L=frac{c^{a_1}+c^{a_2}+…+c^{a_m}}m$
    推导过程:显然对于第 $i$ 个置换来说,不动点要求所有循环的颜色相同,每个循环有 $c$ 种颜色选择,所以该置换的不动点数目为 $c^{a_i}$ 。

    那么考虑每种置换的循环数目:

    如果没有翻转操作:设旋转 $k$ 个位置,考虑一个循环的大小 $x$ ,实际上就是 $kxmod r=0$ 的最小正整数解(转了 $x$ 次后回到原处)。
    显然 $x=frac{ ext{lcm}(k,r)}{k}=frac{r}{gcd(k,r)}$ ,因此循环个数为 $frac{r}{frac{r}{gcd(k,r)}}=gcd(k,r)$ ,方案数为 $c^{gcd(k,r)}$

    如果有翻转操作:对于任意的 旋转-翻转-旋转 操作都等同于一次翻转操作。因此只需要统计所有本质不同的翻转操作的答案。
    当 $r$ 为奇数时,对称轴为 某点-对边中点 ,显然这样置换有 $r$ 种,每个置换有 $frac{r+1}{2}$ 个循环。因此答案为 $rc^{frac{r+1}{2}}$
    当 $r$ 为偶数时,对称轴为 某点-对点 时,置换有 $frac r2$ 种,每个置换有 $frac r2+1$ 个循环;对称轴为 某边-对边中点 时,置换有 $frac r2$ 种,每种置换有 $frac r2$ 个循环。因此答案为 $frac r2(c^{frac r2}+c^{frac r2+1})$

    把这两部分加起来即为答案。

    #include <cstdio>
    typedef long long ll;
    int gcd(int a , int b)
    {
    	return b ? gcd(b , a % b) : a;
    }
    int main()
    {
    	int n , m , i , d;
    	ll ans , t;
    	while(~scanf("%d%d" , &m , &n) && (n || m))
    	{
    		ans = 0;
    		for(i = 1 ; i <= n ; i ++ )
    		{
    			t = 1 , d = gcd(i , n);
    			while(d -- ) t *= m;
    			ans += t;
    		}
    		if(n & 1)
    		{
    			t = n;
    			for(i = 1 ; i <= n / 2 + 1 ; i ++ ) t *= m;
    			ans += t;
    		}
    		else
    		{
    			t = n / 2;
    			for(i = 1 ; i <= n / 2 ; i ++ ) t *= m;
    			ans += t;
    			t = n / 2;
    			for(i = 1 ; i <= n / 2 + 1 ; i ++ ) t *= m;
    			ans += t;
    		}
    		printf("%lld
    " , ans / 2 / n);
    	}
    	return 0;
    }
    
  • 相关阅读:
    PID入门的十五个基本概念
    串级调节系统参数整定方法(串级调节器参数整定)
    PID参数整定快速入门(调节器参数整定方法)
    在 Altium designer 09 中显示隐藏飞线
    如何高效利用GitHub
    基于markdown的blog系统调研1:typecho
    使用GitBook, Git github, Markdown 快速发布你的书籍
    献给写作者的 Markdown 新手指南及语法
    ubuntu搭建Git服务器
    CentOS搭建git服务器实测
  • 原文地址:https://www.cnblogs.com/GXZlegend/p/8296673.html
Copyright © 2011-2022 走看看