博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
uoj21 【UR #1】缩进优化
阅读量:5146 次
发布时间:2019-06-13

本文共 1723 字,大约阅读时间需要 5 分钟。

题意简介明了,需要找到一个\(T\),最小化

\[\sum_{i=1}^n\left \lfloor \frac{a_i}{T} \right \rfloor+\sum_{i=1}^na_i\%T\]

非常显然的\(a_i\%T=a_i-\left \lfloor \frac{a_i}{T} \right \rfloor\times T\)

于是

\[\sum_{i=1}^n\left \lfloor \frac{a_i}{T} \right \rfloor+\sum_{i=1}^na_i-T\times \sum_{i=1}^n\left \lfloor \frac{a_i}{T} \right \rfloor\]

即为

\[\sum_{i=1}^na_i-(T-1)\sum_{i=1}^n\left \lfloor \frac{a_i}{T} \right \rfloor\]

最小化这个柿子只需要最大化\((T-1)\sum_{i=1}^n\left \lfloor \frac{a_i}{T} \right \rfloor\)

考虑一次枚举\(T\),需要快速求出\(\sum_{i=1}^n\left \lfloor \frac{a_i}{T} \right \rfloor\)

注意到\(\left \lfloor \frac{a_i}{T} \right \rfloor\)只会有\(\left \lfloor \frac{\max a_i}{T} \right \rfloor\)种值,即对于\(a_i\in[0,T-1],\left \lfloor \frac{a_i}{T} \right \rfloor=0...a_i\in [kT-T,kT-1],\left \lfloor \frac{a_i}{T} \right \rfloor=k\)

我们直接暴力这\(\left \lfloor \frac{\max a_i}{T} \right \rfloor\)段区间,前缀和算一下这段区间里有多少个\(a_i\)即可

复杂度显然调和级数,视\(n\)\(\max a_i\)同级,复杂度为\(O(n\log n)\)

代码

#include
#define re register#define LL long long#define max(a,b) ((a)>(b)?(a):(b))const int maxn=1e6+5;inline int read() { char c=getchar();int x=0;while(c<'0'||c>'9') c=getchar(); while(c>='0'&&c<='9') x=(x<<3)+(x<<1)+c-48,c=getchar();return x;}int n,pre[maxn],T;LL ans,tmp;inline int calc(int l,int r) { return (r>T?pre[T]:pre[r])-(l?pre[l-1]:0);}int main() { n=read(); for(re int x,i=1;i<=n;i++) x=read(),ans+=x,T=max(T,x),pre[x]++; for(re int i=1;i<=T;i++) pre[i]+=pre[i-1]; for(re int i=2;i<=T;++i) { LL now=0; for(re int cnt=0,l=0,j=i-1;l<=T;j+=i,l+=i,++cnt) now+=1ll*calc(l,j)*cnt; if(1ll*now*(i-1)>tmp) tmp=1ll*now*(i-1); } printf("%lld\n",ans-tmp); return 0;}

转载于:https://www.cnblogs.com/asuldb/p/11455826.html

你可能感兴趣的文章
CocoaPod
查看>>
css3实现漂亮的按钮链接
查看>>
[python基础] python 2与python 3的区别,一个关于对象的未知的坑
查看>>
BZOJ 1251: 序列终结者 [splay]
查看>>
深度剖析post和get的区别
查看>>
云的世界
查看>>
初识DetNet:确定性网络的前世今生
查看>>
5G边缘网络虚拟化的利器:vCPE和SD-WAN
查看>>
MATLAB基础入门笔记
查看>>
【UVA】434-Matty&#39;s Blocks
查看>>
五、宽度优先搜索(BFS)
查看>>
运行一个窗体直接最大化并把窗体右上角的最大化最小化置灰
查看>>
Android开发技术周报 Issue#80
查看>>
hadoop2.2.0+hive-0.10.0完全分布式安装方法
查看>>
WebForm——IIS服务器、开发方式和简单基础
查看>>
小实验3:实现haproxy的增、删、查
查看>>
Angular中ngModel的$render的详解
查看>>
读《格局》| 未到年纪的真理
查看>>
[转]《城南旧事》里的《送别》
查看>>
07动手动脑
查看>>