1414 冰雕 51nod 暴力
2024-08-30 05:28:08
收藏
关注
白兰大学正在准备庆祝成立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);
}
}
最新文章
- Android之如何使用JUnit进行单元测试
- win7 解决IE浏览器不能打开网页的问题
- 基于Material Design(转载)
- TimeVal类——Live555源码阅读(一)基本组件类
- Compiling Inkscape on Windows
- Flume学习——Flume的架构
- [转] java中的匿名内部类总结
- if/else 条件
- 解决Postman发送post数据但是Node.js中req.body接收不到数据的问题[已解决]
- zencart 具体页面调用规则: $body_code变量解析
- ProjectManager Beta 2 项目管理器发布
- Recurrent Neural Network系列4--利用Python,Theano实现GRU或LSTM
- win10 + Debian9.1双系统安装笔记
- jmeter的使用---web测试
- Docker 安装以及运用
- Spring Boot web API接口设计之token、timestamp、sign
- [转]cximage双缓冲绘图 .
- PCL点云特征描述与提取(3)
- linux下抓包学习--tcpdump的使用
- bzoj千题计划118:bzoj1028: [JSOI2007]麻将