标签:
| Time Limit: 1000MS | Memory Limit: 10000K | |
| Total Submissions: 7061 | Accepted: 2942 |
Description

Input
Output
Sample Input
4 5 -1
Sample Output
21 39
Source
题目大意:
n个珠子串成一个圆,用三种颜色去涂色。问一共有多少种不同的涂色方法。
不同的涂色方法被定义为:如果这种涂色情况翻转,旋转不与其他情况相同就为不同。
解题思路:
Polya定理模版题。
对于顺时针长度为i的旋转,为pow(3,__gcd(n,i);
对于翻转,当为奇数时,有:n*pow(3.0,n/2+1);
当为偶数时,有:n/2*pow(3.0,n/2)+n/2*pow(3.0,n/2+1);
一共有2*n种情况,最后要除以2*n
ac代码
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
int gcd(int a,int b)
{
if(a<b)
{
int temp=a;
a=b;
b=temp;
}
if(b==0)
return a;
return gcd(b,a%b);
}
int main()
{
int n;
while(scanf("%d",&n)!=EOF,n!=-1)
{
int i;
if(n<=0)
{
printf("0\n");
continue;
}
__int64 ans=0;
for(i=1;i<=n;i++)
ans+=pow(3.0,gcd(i,n));
if(n&1)
ans+=n*pow(3.0,n/2+1);
else
{
ans+=n/2*pow(3.0,n/2+1);
ans+=n/2*pow(3.0,n/2);
}
ans/=2*n;
printf("%I64d\n",ans);
}
}
POJ 题目1286 Necklace of Beads(Polya定理)
标签:
原文地址:http://blog.csdn.net/yu_ch_sh/article/details/45487041