标签:
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