ABC136 E - Max GCD 题解
题面
给定一个长度为 $N$ 的整数序列:$A_1, A_2, \ldots, A_n$。
您可以执行以下操作 $0 \sim K$ 次:
选择两个整数 $i$ 和 $j$,满足 $i \ne j$ 并且 $1 \le i, j \le N$。令 $A_i$ 加上 $1$,令 $A_j$ 减去 $1$,可能产生负的元素。
计算在执行完操作后,整除 $A$ 中每个元素的最大可能正整数。这里正整数 $x$ 整除整数 $y$ 当且仅当存在一个整数 $z$,使得 $y=xz$。
思路
容易发现\(n\)很小,且答案\(ans\)一定为序列的权值和的因子,又发现,无论经过多少次操作后,总和均不变。考虑枚举\(ans\),记录下每一个值在当前情况下的余数,排序后用双指针找需要把所以余数都归零的操作次数,是否大于k判合法性即可
code
点击查看代码
#include <bits/stdc++.h>
using namespace std;
int read() {
int a=0,f=0;
char c=getchar();
for(; c<'0'||c>'9'; c=getchar())if(c=='-')f=1;
for(; c>='0'&&c<='9'; c=getchar())a=a*10+c-'0';
return f?-a:a;
}
const int N=5e2+10;
int n,sum=0,ans=0,k,kk;
int p[N],b[N];
int main() {
n=read(),k=read(),kk=k;
for(int i=1; i<=n; ++i) p[i]=read(),sum+=p[i];
// cout<<sum<<endl;
for(int i=1; i<=sum; ++i) {
// cout<<"sy "<<i<<" "<<sum<<" "<<sum%i<<endl;
if(sum%i!=0) continue;
int x=sum/i;
// cout<<"i: "<<i<<endl;
k=kk;
for(int j=1; j<=n; ++j) {
b[j]=p[j]%i;
}
sort(b+1,b+1+n);
bool flag=0;
int kun=0,l=1,r=n;
// cout<<"b: ";
// for(int d=1; d<=n; ++d) {
// cout<<b[d]<<" ";
// }
// cout<<endl;
while(l<=r) {
// cout<<"b: ";
// for(int d=1; d<=n; ++d) {
// cout<<b[d]<<" ";
// }
// cout<<endl;
int fl=b[l],fr=b[r],gl=fl,gr=i-fr;
// cout<<i<<" "<<l<<" "<<r<<" "<<gl<<" "<<gr<<" "<<k<<" "<<sum<<endl;
if(b[l]==0) {
l++;
continue;
}
if(fl+fr==i) {
k-=fl;
if(k<0) {
flag=1;
break;
}
l++,r--;
continue;
}
if(gl>gr) {
k-=gr;
b[l]-=gr;
r--;
if(k<0) {
flag=1;
break;
}
continue;
}
if(gl<gr) {
k-=gl;
b[r]+=gl;
l++;
if(k<0) {
flag=1;
break;
}
continue;
}
}
// cout<<"i: "<<flag<<endl;
if(!flag) {
ans=max(ans,i);
}
}
cout<<ans;
return 0;
}
/*
8 7
1 7 5 6 8 2 6 5
*/
ABC136 E - Max GCD 题解的更多相关文章
- HDU5726:GCD——题解
题目:hdu的5726 (我原博客的东西,正好整理过来,属于st表裸题) (可以看出我当时有多么的菜--) 这道题写了一遍,然而蒟蒻的我的时间爆炸了-- 于是看了一下学长的代码(顺便在此处%一下学长) ...
- 洛谷 P2568 GCD 题解
原题链接 庆祝一下:数论紫题达成成就! 第一道数论紫题.写个题解庆祝一下吧. 简要题意:求 \[\sum_{i=1}^n \sum_{j=1}^n [gcd(i,j)==p] \] 其中 \(p\) ...
- Hdoj 1003.Max Sum 题解
Problem Description Given a sequence a[1],a[2],a[3]......a[n], your job is to calculate the max sum ...
- BZOJ2820:YY的GCD——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=2820 Description 神犇YY虐完数论后给傻×kAc出了一题给定N, M,求1<=x& ...
- CC DGCD:Dynamic GCD——题解
https://vjudge.net/problem/CodeChef-DGCD https://www.codechef.com/problems/DGCD 题目大意: 给一颗带点权的树,两个操作: ...
- CH 4302 Interval GCD 题解
题意 给定一个长度为N的数列A,以及M条指令 (N≤5* 10^5, M<=10^5),每条指令可能是以下两种之一: "C l r d",表示把 A[l],A[l+1],-, ...
- gcd 题解
gcd Little White learned the greatest common divisor, so she plan to solve a problem: given \(x, n,\ ...
- ABC136E Max GCD
Thinking about different ways of thinking. --- LzyRapx 题目 思路比较容易想到. Observations: 每次操作过后和不变. 枚举和的因子 ...
- [洛谷2257]YY的GCD 题解
整理题目转化为数学语言 题目要我们求: \[\sum_{i=1}^n\sum_{i=1}^m[gcd(i,j)=p]\] 其中 \[p\in\text{质数集合}\] 这样表示显然不是很好,所以我们需 ...
- luoguP3128 [USACO15DEC]最大流Max Flow 题解(树上差分)
链接一下题目:luoguP3128 [USACO15DEC]最大流Max Flow(树上差分板子题) 如果没有学过树上差分,抠这里(其实很简单的,真的):树上差分总结 学了树上差分,这道题就极其显然了 ...
随机推荐
- PKU2506Tiling
https://blog.csdn.net/Harington/article/details/86612106
- 实验五Elasticsearch+Kibana展示爬虫数据
安装elasticsearch-rtf Elasticsearch-rtf相比于elasticsearch而言多加了一些插件,因此我们选择安装Elasticsearch-rtf是一个不错的选择.在安装 ...
- Deer_GF之【AssetsHotfix】和【AssetsNative】文件夹的区别
Hi,今天介绍一下Deer_Gf里的[AssetsHotfix]和[AssetsNative]文件夹的区别: 框架介绍请移步[Deer_GF之框架介绍] 一.[AssetsHotfix] ...
- Beautiful Soup库的安装
安装:'以管理员身份运行'cmd 执行pip install beautifulsoup4 Beautiful Soup库的理解: 解析.遍历.维护标签树的功能库 那么何为标签树? 1 from bs ...
- 下载nvm并安装vue环境
nvm下载地址 https://github.com/coreybutler/nvm-windows/releases 直接下载 nvm-setup.zip 到任意文件夹下,双击安装 安装过程会提示 ...
- mysql8使用tmpfs内存磁盘当内存数据库的配置方法
序: 内存关系数据库没有找到开源好用的,很多都是商用.虽然mysql有memory引擎,但写是整体锁表,没法用. 一直想将mysql放入内存中,搜索n次资料,没找到合适的,可能之前思路不对. 最近在测 ...
- mysql使用经验
1.mysql建表主键,如果整数,用bigint而不用int 2.执行sql加最大执行时间 /*+ max_execution_time(60000)*/ 3.sql中避免offset过大,查询不出来
- notepad++ 配置Java 环境
(1)设计新建文件的类型与编码方式: (2)安装插件NppExec (3)插件配置 (4)编辑并配置命令: 找到Advance Options; 在红中找到Java,点击 (5)运行结果查看: (6) ...
- sql server某列根据逗号转多行,其它字段不变
效果: 语句代码: declare @moulds varchar(4000); set @moulds='55-480730-03,55-487780-01,,55-487780-02 '; dec ...
- CSS控制背景图片100%自适应填充布局
原文地址:http://blog.csdn.net/wd4java/article/details/50537562 .personal_head { width: 100%; height: 35% ...