zoukankan      html  css  js  c++  java
  • Codeforces 71C Round Table Knights

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

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

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

    解题代码:

     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("
    ");*/
    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
    ");
    84             return 0 ; 
    85           }
    86     }
    87     printf("NO
    ");
    88 return 0;
    89 }
    View Code
    没有梦想,何谈远方
  • 相关阅读:
    PDB文件详解
    C++模板常用功能讲解
    Windows下多线程编程(二)
    关于静态库中使用全局变量可能导致的问题
    js中的函数
    js中字符串的加密base64
    列表推导式
    函数和方法的区别
    xshell连不上虚拟机
    网络编程,并行,并发和协程
  • 原文地址:https://www.cnblogs.com/zyue/p/4354808.html
Copyright © 2011-2022 走看看