题目来源: CodeForces
基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题
 收藏
 关注

白兰大学正在准备庆祝成立256周年。特别任命副校长来准备校园的装扮。

校园的中心竖立着n个冰雕。这些雕像被排在一个等分圆上,因此他们形成了一个正n多边形。这些冰雕被顺针地从1到n编号。每一个雕有一个吸引力t[i].

校长来看了之后表示不满意,他想再去掉几个雕像,但是剩下的雕像必须满足以下条件:

·        剩下的雕像必须形成一个正多边形(点数必须在3到n之间,inclusive),

·        剩下的雕像的吸引力之和要最大化。

请写一个程序帮助校长来计算出最大的吸引力之和。如果不能满足上述要求,所有雕像不能被移除。

Input
单组测试数据。
第一行输入一个整数n(3≤n≤20000),表示初始的冰雕数目。
第二行有n个整数t[1],t[2],t[3],…,t[n],表示每一个冰雕的吸引力(-1000≤t[i]≤1000),两个整数之间用空格分开。
Output
输出答案占一行。
Input示例
8
1 2 -3 4 -5 5 2 3
6
1 -2 3 -4 5 -6
Output示例
14
9
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<sstream>
#include<algorithm>
#include<queue>
#include<deque>
#include<iomanip>
#include<vector>
#include<cmath>
#include<map>
#include<stack>
#include<set>
#include<fstream>
#include<memory>
#include<list>
#include<string>
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
#define MAXN 20009
#define N 21
#define MOD 1000000
#define INF 1000000009
const double eps = 1e-;
const double PI = acos(-1.0);
/*
注意到MAXN比较小,可以用暴力试一试
*/
int a[MAXN], ans, n;
int main()
{
while (scanf("%d", &n) != EOF)
{
for (int i = ; i < n; i++)
scanf("%d", &a[i]);
ans = -INF;
for (int i = ; i <= n / ; i++)//最少是正三角形,枚举顶点之间的间距,在1到n/3
{
if (n%i) continue;//无法通过去点组成该正多边形
for (int j = ; j < i; j++)//枚举起点
{
int tmp = ;
for (int k = j; k < n; k += i)//计算吸引力之和
tmp += a[k];
ans = max(ans, tmp);
}
}
printf("%d\n", ans);
}
}

最新文章

  1. Android之如何使用JUnit进行单元测试
  2. win7 解决IE浏览器不能打开网页的问题
  3. 基于Material Design(转载)
  4. TimeVal类——Live555源码阅读(一)基本组件类
  5. Compiling Inkscape on Windows
  6. Flume学习——Flume的架构
  7. [转] java中的匿名内部类总结
  8. if/else 条件
  9. 解决Postman发送post数据但是Node.js中req.body接收不到数据的问题[已解决]
  10. zencart 具体页面调用规则: $body_code变量解析
  11. ProjectManager Beta 2 项目管理器发布
  12. Recurrent Neural Network系列4--利用Python,Theano实现GRU或LSTM
  13. win10 + Debian9.1双系统安装笔记
  14. jmeter的使用---web测试
  15. Docker 安装以及运用
  16. Spring Boot web API接口设计之token、timestamp、sign
  17. [转]cximage双缓冲绘图 .
  18. PCL点云特征描述与提取(3)
  19. linux下抓包学习--tcpdump的使用
  20. bzoj千题计划118:bzoj1028: [JSOI2007]麻将

热门文章

  1. 如何通过DirectInput技术针对莱仕达雷驰V3II游戏方向盘编程
  2. frameset的target属性
  3. Java经典算法之插入排序(Insert Sort)
  4. VUE移动端禁止双手放大缩小
  5. Android框架式编程之Room
  6. Kafka详解与总结(四)
  7. PKUSC2017 游记 密码:blog密码
  8. Codeforces 825D 二分贪心
  9. NOIP真题汇总
  10. 【原】cocos2d-x开发笔记:获取Sprite上某一个点的透明度,制作不规则按钮