题意:有n个点均匀的分布在圆周上,每个点有0,1两种状态,问你所有 1的点能否组成正多边形。

解题思路:数论 + dp  ,假设可以组成正 t 边形 ,那么 t 一定要是 n的因子 ,又因为如果能组成 正t边形 ,一定能组成 正 2*t 边形,3*t边行等等,所以只需要质因子。

然后用 0 去排除这些质因子是否可行就行了。

解题代码:

Codeforces  71C   Round Table Knights_#defineCodeforces  71C   Round Table Knights_DP_02
 1 // File Name: 71c.cpp
 2 // Author: darkdream
 3 // Created Time: 2015年03月20日 星期五 21时45分50秒
 4 
 5 #include<vector>
 6 #include<list>
 7 #include<map>
 8 #include<set>
 9 #include<deque>
10 #include<stack>
11 #include<bitset>
12 #include<algorithm>
13 #include<functional>
14 #include<numeric>
15 #include<utility>
16 #include<sstream>
17 #include<iostream>
18 #include<iomanip>
19 #include<cstdio>
20 #include<cmath>
21 #include<cstdlib>
22 #include<cstring>
23 #include<ctime>
24 #define LL long long
25 #define maxn 100001
26 using namespace std;
27 int a[100005];
28 int hs[100005];
29 int n;
30 int tt;
31 int zyz[10];
32 int dp[10][100050];
33 void sai()
34 {
35    int li = sqrt(n)+1;
36    for(int i = 2;i <= li ;i ++)
37    { 
38       if(hs[i] == 0)
39       {
40         int k = i*i ;
41         while(k <= n)
42         {
43            hs[k] = 1; 
44            k += i ; 
45         }
46       }
47    }
48    hs[4] = 0 ; 
49    hs[2] = 1; 
50    tt = 0 ; 
51    for(int  i = 2;i <= n ;i ++)
52    {
53      if(hs[i] == 0 && n % i == 0 )
54      {
55        tt ++ ;
56        zyz[tt] = n/i ; 
57      }
58    }
59 }
60 int main(){
61     scanf("%d",&n);
62     sai();
63     /*for(int i = 1;i <= tt; i ++)
64         printf("%d ",zyz[i]);
65     printf("\n");*/
66     int tmp ; 
67     for(int i = 1;i <= n;i ++)
68     {
69        scanf("%d",&tmp);
70        if(tmp == 0 )
71        {
72        for(int j = 1; j <= tt; j++)
73        {
74            dp[j][i%zyz[j]] = 1;
75        }
76        }
77     }
78     for(int i = 1;i <= tt;i ++)
79     {
80       for(int j =0 ;j < zyz[i];j ++)
81           if(dp[i][j] == 0)
82           {
83             printf("YES\n");
84             return 0 ; 
85           }
86     }
87     printf("NO\n");
88 return 0;
89 }
View Code