博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CF889E Mod Mod Mod
阅读量:6882 次
发布时间:2019-06-27

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

题解

首先我们观察到在每次取模的过程中一定会有一次的结果是\(a_i-1\),因为如果不是,我们可以调整,答案肯定是会更优的。

于是我们的有用状态就变成了\(O(n)\)级别。

我们可以对于一个状态,把它表示为\((a,b)\),表示前\(i\)个数,当前取完模的结果为\(a\),总和写成\(i*a+b\)的形式后最大的\(b\)

我们的转移每次要把\(a\)变成\(a%v\),再添加一个新状态\(v-1\)

转移讨论一下。

代码

#include
#define N 200009using namespace std;typedef long long ll;const int mod=1e9+7;map
f;map
::iterator it;int n;inline ll rd(){ ll x=0;char c=getchar();bool f=0; while(!isdigit(c)){if(c=='-')f=1;c=getchar();} while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=getchar();} return f?-x:x;}int main(){ n=rd(); f[rd()-1]=0; for(int i=2;i<=n;++i){ ll x=rd(); while(!f.empty()){ it=f.end();--it; ll a=it->first,b=it->second; if(a
first*n+it->second); cout<

转载于:https://www.cnblogs.com/ZH-comld/p/11020728.html

你可能感兴趣的文章
什么?What?调用系统的相册和相机的时候,系统按钮全是这种小白块,到底什么鬼??...
查看>>
从一个实例看java,new一个对象时的初始化顺序
查看>>
关于小型园区网的HSRP热备以及web、DHCP服务器
查看>>
设备不显示LOG信息
查看>>
如何写出优雅的Javascript代码
查看>>
Centos 6.4 用yum安装kde桌面
查看>>
VIM的小插件合集(持续更新)
查看>>
解除账户锁定,解除账户过期锁定
查看>>
Using Vim as c/c++ editor
查看>>
网络存储资料整理
查看>>
推荐一个 短链接服务
查看>>
安全管理平台 security management platform
查看>>
CCNA学习笔记之OSPF(理论篇)
查看>>
更改linux主机名
查看>>
centos设置时间自动与网络同步
查看>>
Practice Backbone.js with PHP :: Example 1
查看>>
最新Ghost Win7系统下载(含32位纯净版和64位旗舰版)
查看>>
openssh升级方法
查看>>
46、mysql双主复制实战
查看>>
jQuery(function(){})与(function(){})(jQuery)的区别
查看>>