Wannafly Camp 2020 Day 3F 社团管理 - 决策单调性dp,整体二分
有 \(n\) 个数构成的序列 \({a_i}\),要将它划分为 \(k\) 段,定义每一段的权值为这段中 \((i,j) \ s.t. \ i<j,\ a_i=a_j\) 的个数,求一种划分方案,使得各段的权值和最小。 \(n \leq 10^5, k \leq min(n,20), a_i \leq n\)
设 \(f[i][j]\) 表示将 \(a_{1..j}\) 分为 \(i\) 段的最小价值,则很容易得到转移方程
\]
暴力转移是 \(O(n^2 k)\),但这里有决策单调性,即 \(p_j\) 为 \(f[i][j]\) 的最优转移点(如果有多个就取最左边的),那么对于任意 \(k<j\) 一定有 \(p_k \leq p_j\)
注:形如 \(f_i = min/max_{j=1}^{i-1} g_j + w_{i,j}\),记 \(f_i\) 的最优决策点为 \(p_i\),即 \(f_i\) 从 \(g_{p_i} + w_{i,p_i}\) 处转移最优,如果满足 \(p_i \leq p_{i+1}\),则称该方程满足决策单调性
(不想证明可以先写个暴力打表然后一眼看规律)
所以我们整体二分来加速转移
考虑我们当前求解一段区间 \([l,r]\),所有 \(f_{i,j},\ j \in [l,r]\) 的最优决策点在 \([L,R]\) 之间。
对于 \([l,r]\) 的中点 \(mid\),可以暴力扫一遍 \([L,R]\),找到最优决策点 \(k\)
那么由于决策单调,所有 \(f_{i,j},\ j \in [l,mid]\) 的决策则落在 \([L,k]\) 上,所有 \(f_{i,j},\ j \in [mid+1,r]\) 的决策则落在 \([k,R]\) 上
总体时间复杂度 \(O(kn \log n)\)
因为某个循环边界写宽了然后就TLE了
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int N = 1000005;
int n,m,f[N],g[N],a[N],buc[N]={1,0},cnt;
signed pl,pr;
inline void push(signed x) {
cnt+=buc[x];
buc[x]++;
}
inline void pop(signed x) {
buc[x]--;
cnt-=buc[x];
}
void trans(signed l,signed r) {
while(l<pl) pl--, push(a[pl]);
while(r>pr) pr++, push(a[pr]);
while(l>pl) pop(a[pl]), pl++;
while(r<pr) pop(a[pr]), pr--;
//cout<<l<<" "<<r<<" "<<cnt<<endl;
}
void solve(int l,int r,int L,int R) {
int mid=(l+r)/2;
int mx=1e18,k=0;
for(int i=L;i<=min(R,mid-1);i++) { //!
trans(i+1,mid);
if(g[i]+cnt<mx) {
mx=g[i]+cnt;
k=i;
}
}
f[mid]=mx;
if(l<r) {
solve(l,(l+r)/2-1,L,k); //!
solve((l+r)/2+1,r,k,R);
}
}
signed main() {
ios::sync_with_stdio(false);
scanf("%lld%lld",&n,&m);
for(int i=1;i<=n;i++) {
scanf("%lld",&a[i]);
}
for(int i=1;i<=n;i++) {
trans(1,i);
f[i]=g[i]=cnt;
//<<g[i]<<" ";
}//cout<<endl;
for(int i=2;i<=m;i++) {
solve(1,n,1,n);
for(int j=1;j<=n;j++) g[j]=f[j];
/*for(int j=1;j<=n;j++) {
cout<<f[j]<<" ";
}
cout<<endl;*/
}
cout<<f[n];
}
Wannafly Camp 2020 Day 3F 社团管理 - 决策单调性dp,整体二分的更多相关文章
- Wannafly Camp 2020 Day 2B 萨博的方程式 - 数位dp
给定 \(n\) 个数 \(m_i\),求 \((x_1,x_2,...,x_n)\) 的个数,使得 \(x_1 \ xor\ x_2\ xor\ ...\ xor\ x_n = k\),且 \(0 ...
- BZOJ_4609_[Wf2016]Branch Assignment_决策单调性+带权二分
BZOJ_4609_[Wf2016]Branch Assignment_决策单调性+带权二分 Description 要完成一个由s个子项目组成的项目,给b(b>=s)个部门分配,从而把b个部门 ...
- BZOJ_5311_贞鱼_决策单调性+带权二分
BZOJ_5311_贞鱼_决策单调性+带权二分 Description 众所周知,贞鱼是一种高智商水生动物.不过他们到了陆地上智商会减半. 这不?他们遇到了大麻烦! n只贞鱼到陆地上乘车,现在有k辆汽 ...
- BZOJ4426 :最大生产率(贪心+决策单调性DP)
题意:给出N个人,现在让你分P组,每组的工作效率是最小结束时间-最大开始时间,要求每一组的效率的正数,求最大效率和.N<1000 思路: 把包含至少一个其他的分到A组:否则到B组. A组的要么单 ...
- CF321E Ciel and Gondolas 【决策单调性dp】
题目链接 CF321E 题解 题意:将\(n\)个人分成\(K\)段,每段的人两两之间产生代价,求最小代价和 容易设\(f[k][i]\)表示前\(i\)个人分成\(k\)段的最小代价和 设\(val ...
- BZOJ2216 [Poi2011]Lightning Conductor 【决策单调性dp】
题目链接 BZOJ2216 题解 学过高中数学都应知道,我们要求\(p\)的极值,参变分离为 \[h_j + sqrt{|i - j|} - h_i \le p\] 实际上就是求\(h_j + sqr ...
- 洛谷 P3515 [ POI 2011 ] Lightning Conductor —— 决策单调性DP
题目:https://www.luogu.org/problemnew/show/P3515 决策单调性... 参考TJ:https://www.cnblogs.com/CQzhangyu/p/725 ...
- LOJ2074/2157 JSOI2016/POI2011 Lightning Conductor 决策单调性DP
传送门 我们相当于要求出\(f_i = \max\limits_{j=1}^{n} (a_j + \sqrt{|i-j|})\).这个绝对值太烦人了,考虑对于\(i>j\)和\(i<j\) ...
- Wannafly Winter Camp 2020 Day 5C Self-Adjusting Segment Tree - 区间dp,线段树
给定 \(m\) 个询问,每个询问是一个区间 \([l,r]\),你需要通过自由地设定每个节点的 \(mid\),设计一种"自适应线段树",使得在这个线段树上跑这 \(m\) 个区 ...
随机推荐
- Python3(九) 闭包
一. 一切皆对象 函数式编程并没有标准定义,如果代码非常繁琐则考虑使用. 学习闭包的概念,不是python独有的. 其他大多数语言中的函数只是一段可执行的代码,并不是对象. python中的函数是对象 ...
- 13-MyBatis03(逆向工程)
MyBatis逆向工程 1.导入jar包 <dependency> <groupId>org.mybatis</groupId> <artifactId> ...
- VMware 克隆 CentOS 后网卡信息修改
概述 在我们需要多台 CentOS 虚拟机的时候,对已有虚拟机的系统进行克隆或是复制.但是这样做又有一个问题,克隆出来的虚拟机启动的时候你输入命令:ifconfig,eth0 网卡信息没了,只有一个 ...
- 字符编码及字节串bytes类型
1 字符编码简介 ASCII码:美国人发明并使用,用1个字节(8位二进制)代表一个字符,ASCII码是其他任意编码表的子集(utf-16除外). Unicode:包含和兼容全世界的语言,与全世界的语言 ...
- JWT实现token-based会话管理(转)
JWT实现token-based会话管理 阅读目录 认识JWT demo要点说明 小结 上文<3种web会话管理的方式>介绍了3种会话管理的方式,其中token-based的方式有必要 ...
- ModbusTCP协议解析 —— 利用Wireshark对报文逐字节进行解析详细解析Modbus所含功能码
现在网上有很多类似的文章.其实这一篇也借鉴了很多其他博主的文章. 写这篇文章的重点是在于解析功能和报文.对Modbus这个协议并不会做很多介绍. 好了,我们开始吧. 常用的功能码其实也没多少.我也就按 ...
- SQL Server 2019 安装教程
SQL Server 2019 安装教程 下载安装SQL: 1.下载SQL Server 2019 Developer 官方网址:下载地址. 2.下拉选择免费版本,直接点击下载(别问,问就是家境贫寒
- C# 多线程之通过Timer开启线程的例子
本例通过Timer的tick()方法触发TimerCallback委托来开辟新的线程,线程中的具体工作通过一个静态方法作为参数给TimerCallback委托. using System; using ...
- 学习 Vim 命令总结
学习 Vim 命令总结 可以使用 vscode-vim 扩展,但是要注意一些ctrl+字母的快捷键会无效,必须去掉冲突的快捷键 esc 回到普通模式 i 普通模式进入插入模式 : 进入命令模式 :wa ...
- Django csrf校验
引入: 通常,钓鱼网站本质是本质搭建一个跟正常网站一模一样的页面,用户在该页面上完成转账功能 转账的请求确实是朝着正常网站的服务端提交,唯一不同的在于收款账户人不同. 如果想模拟一个钓鱼网站,就可是给 ...