1414 冰雕
白兰大学正在准备庆祝成立256周年。特别任命副校长来准备校园的装扮。
校园的中心竖立着n个冰雕。这些雕像被排在一个等分圆上,因此他们形成了一个正n多边形。这些冰雕被顺针地从1到n编号。每一个雕有一个吸引力t[i].
校长来看了之后表示不满意,他想再去掉几个雕像,但是剩下的雕像必须满足以下条件:
· 剩下的雕像必须形成一个正多边形(点数必须在3到n之间,inclusive),
· 剩下的雕像的吸引力之和要最大化。
请写一个程序帮助校长来计算出最大的吸引力之和。如果不能满足上述要求,所有雕像不能被移除。
收起
输入
单组测试数据。
第一行输入一个整数n(3≤n≤20000),表示初始的冰雕数目。
第二行有n个整数t[1],t[2],t[3],…,t[n],表示每一个冰雕的吸引力(-1000≤t[i]≤1000),两个整数之间用空格分开。
输出
输出答案占一行。
输入样例
8
1 2 -3 4 -5 5 2 3
6
1 -2 3 -4 5 -6
输出样例
14
9
题意概述:
给出N个点构成一个正多边形,N个点每个点一个权值,从中去掉一些点,使得最终的图形还是正多边形,求最终权值和最大的方案。
思路分析:
错误思路:选一部分点去掉,求最小权值和,(选点方法:N的因子,每部分中取一个点去掉)sum-mini作为最终结果之一,想法没错,但错误之处在于对需要去掉的点的选择上,考虑去掉的点构成的图形是否一定是正多边形,答案是不一定,那么最后剩下的点是否一定是多边形,答案肯定,上述括号内的选点方案选出的点一定是正多边形,而需要去掉的点只是对称即可,没那么高要求,一定正多边形,所以要么更换选点策略,要么转枚举去掉的点为枚举剩下的点。简单起见,选择第二种方案。
代码思路:
1、输入数据
2、枚举剩余点个数 i:3~n并筛去不合要求的;
3、枚举循环起点j:1~n/i
4、枚举本次循环起点及长度下的所有相应点,求和
5、对比答案继续2.
代码实现:
#include<iostream>
#include<cstring>
#include<cmath>
#include<queue>
#include<algorithm>
#define LL long long
#define INF 0x3f3f3f3f
using namespace std;
const int N=2e5+100;
LL arr[N],fac[N];
int main() {
//freopen("in.txt","r",stdin);
int n,sum=0,tmp=0;
cin>>n;
for(int i=1;i<=n;i++)cin>>arr[i],sum+=arr[i];
// cout<<sum<<endl;
int maxs=sum;
for(int i=3;i<=n;i++){
if(n%i!=0)continue;
int up=n/i;
for(int j=1;j<=up;j++){
tmp=0;
for(int k=j;k<=n;k+=up){
tmp+=arr[k];
}
maxs=max(maxs,tmp);
}
}
//cout<<sum-maxs<<endl;
cout<<maxs<<endl;
return 0;
}
The end;