BZOJ 1835 基站选址(线段树优化DP)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1835
题意:有N个村庄坐落在一条直线上,第 i(i>1)个村庄距离第1个村庄的距离为Di。需要在这些村庄中建立不超过K个通讯基站,在第i个村庄建立基站的费用为Ci。如果在距离第i个村 庄不超过Si的范围内建立了一个通讯基站,那么就成它被覆盖了。如果第i个村庄没有被覆盖,则需要向他们补偿,费用为Wi。现在的问题是,选择基站的位 置,使得总费用最小。
思路:
另外,程序中的n=n+1,m=m+1。因
为每次使用f[n]更新答案的,而f[n]的含义是在n位置建立一个通讯站,但是显然有时候最优值并不是一定要在n建立一个。将n+1之后,m+1,则
m+1个必然建立在n+1,而这一个在我们计算st和ed数组时看出他们是不对前面的有影响的。因此统计f[n+1]才是正确的。
struct Node { int L,R; i64 Min,det; void set(i64 x) { det+=x; Min+=x; } }; Node a[N<<2]; void pushUp(int t) { if(a[t].L==a[t].R) return; a[t].Min=min(a[t*2].Min,a[t*2+1].Min); } i64 f[N],ans; void build(int t,int L,int R) { a[t].L=L; a[t].R=R; a[t].det=0; if(L==R) { a[t].Min=f[L]; return; } int mid=(L+R)>>1; build(t*2,L,mid); build(t*2+1,mid+1,R); pushUp(t); } void pushDown(int t) { if(a[t].L==a[t].R) return; if(a[t].det) { a[t*2].set(a[t].det); a[t*2+1].set(a[t].det); a[t].det=0; } } void add(int t,int L,int R,i64 x) { if(L>a[t].R||R<a[t].L) return; if(L<=a[t].L&&a[t].R<=R) { a[t].set(x); return; } pushDown(t); add(t*2,L,R,x); add(t*2+1,L,R,x); pushUp(t); } i64 query(int t,int L,int R) { if(L>a[t].R||R<a[t].L) return inf; if(L<=a[t].L&&a[t].R<=R) return a[t].Min; pushDown(t); i64 ans=min(query(t*2,L,R),query(t*2+1,L,R)); pushUp(t); return ans; } int n,m,d[N],c[N],s[N],w[N]; int st[N],ed[N]; vector<int> V[N]; int getL(int x,int pos) { int low=1,high=pos,mid; while(low<=high) { mid=(low+high)>>1; if(d[mid]>=x) high=mid-1; else low=mid+1; } if(high>=1&&d[high]>=x) return high; return low; } int getR(int x,int pos) { int low=pos,high=n,mid; while(low<=high) { mid=(low+high)>>1; if(d[mid]>x) high=mid-1; else low=mid+1; } if(low<=n&&d[low]<=x) return low; return high; } void init() { int i; FOR1(i,n) { st[i]=getL(d[i]-s[i],i); ed[i]=getR(d[i]+s[i],i); V[ed[i]].pb(i); } } void DP() { build(1,0,n); int i,j,k; FOR1(i,n) { f[i]=query(1,0,i-1)+c[i]; FOR0(j,SZ(V[i])) { k=V[i][j]; add(1,0,st[k]-1,w[k]); } } upMin(ans,f[n]); } int main() { RD(n,m); int i; for(i=2;i<=n;i++) RD(d[i]); FOR1(i,n) RD(c[i]); FOR1(i,n) RD(s[i]); FOR1(i,n) RD(w[i]); FOR1(i,n) f[i]=inf; init(); ans=inf; n++; m++; FOR1(i,m) DP(); PR(ans); }
BZOJ 1835 基站选址(线段树优化DP)的更多相关文章
- 洛谷$P2605\ [ZJOI2010]$基站选址 线段树优化$dp$
正解:线段树优化$dp$ 解题报告: 传送门$QwQ$ 难受阿,,,本来想做考试题的,我还造了个精妙无比的题面,然后今天讲$dp$的时候被讲到了$kk$ 先考虑暴力$dp$?就设$f_{i,j}$表示 ...
- BZOJ 1835 [ZJOI2010]基站选址 (线段树优化DP)
题目大意:略 洛谷题面传送门 BZOJ题面传送门 注意题目的描述,是村庄在一个范围内去覆盖基站,而不是基站覆盖村庄,别理解错了 定义$f[i][k]$表示只考虑前i个村庄,一共建了$k$个基站,最后一 ...
- [ZJOI2010]基站选址,线段树优化DP
G. base 基站选址 内存限制:128 MiB 时间限制:2000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 题目描述 有N个村庄坐落在一条直线上,第i(i>1)个村庄距离 ...
- luogu P2605 [ZJOI2010]基站选址 线段树优化dp
LINK:基站选址 md气死我了l达成1结果一直调 显然一个点只建立一个基站 然后可以从左到右进行dp. \(f_{i,j}\)表示强制在i处建立第j个基站的最小值. 暴力枚举转移 复杂度\(n\cd ...
- luogu2605 基站选址 (线段树优化dp)
设f[i][j]表示在第i个村庄建第j个基站的花费 那么有$f[i][j]=min\{f[k][j-1]+w[k,i]\}$,其中w[k,i]表示在k,i建基站,k,i中间的不能被满足的村庄的赔偿金之 ...
- BZOJ1835: [ZJOI2010]base 基站选址(线段树优化Dp)
Description 有N个村庄坐落在一条直线上,第i(i>1)个村庄距离第1个村庄的距离为Di.需要在这些村庄中建立不超过K个通讯基站,在第i个村庄建立基站的费用为Ci.如果在距离第i个村庄 ...
- Codeforces Round #426 (Div. 2) D 线段树优化dp
D. The Bakery time limit per test 2.5 seconds memory limit per test 256 megabytes input standard inp ...
- BZOJ2090: [Poi2010]Monotonicity 2【线段树优化DP】
BZOJ2090: [Poi2010]Monotonicity 2[线段树优化DP] Description 给出N个正整数a[1..N],再给出K个关系符号(>.<或=)s[1..k]. ...
- [AGC011F] Train Service Planning [线段树优化dp+思维]
思路 模意义 这题真tm有意思 我上下楼梯了半天做出来的qwq 首先,考虑到每K分钟有一辆车,那么可以把所有的操作都放到模$K$意义下进行 这时,我们只需要考虑两边的两辆车就好了. 定义一些称呼: 上 ...
- 【bzoj3939】[Usaco2015 Feb]Cow Hopscotch 动态开点线段树优化dp
题目描述 Just like humans enjoy playing the game of Hopscotch, Farmer John's cows have invented a varian ...
随机推荐
- 管理科学与工程 国内核心期刊 国外a刊及SCI
国内: 管理科学与工程: 管理科学学报 A+ (匿名审稿,绝对牛刊,不比一般的SCi期刊的质量差) 系统工程理论与实践 A (实名审稿,关系稿很多,尤其是挂编委的文章很多,但质量尚可)系统工程 ...
- vim下正则表达式的非贪婪匹配
贪婪模式是: .* 非贪婪模式是: .\{-}
- Xml游标
Mainactivity package com.exmple.xmlstream; import java.util.ArrayList; import java.util.List; import ...
- Gson将参数放入实体类中进行包装之后再传递
package com.sinoservices.dms.orderinfo.entity; public class OrderDetailKeyCondition { //工单主键 private ...
- USB HID描述符【转】
本文转载自: USB是个通用的总线,端口都是统一的.但是USB设备却各种各样,例如USB鼠标,USB键盘,U盘等等,那么USB主机是如何识别出不同的设备的呢?这就要依赖于描述符了.USB的描述符主要有 ...
- Github上PHP资源汇总大全,php学习的好资料
Github上PHP资源汇总大全,php学习的好资料 国外程序员ziadoz 在Github上收集整理了PHP的各种资源,内容包括模板.框架.数据库.安全等方面的库和工具.汇总了各种PHP资源,供各位 ...
- flex 加载arcgis 的地图json
var fs:FeatureSet=FeatureSet.fromJSON(JSONUtil.decode(e.result.toString())); for each(var gra:Graphi ...
- 删除ecshop登录后台看到的系统信息
登陆ecshop后台,默认打开在页面顶部会出现个系统信息,显示操作系统,数据库版本,以及安装日期系统版本号.部分客户问到怎么删除,这里最模板提供ecshop教程告诉大家方法. 找到admin\temp ...
- iOS开发系列之 itms-services 协议
通过 itms-services 协议,发布或者分享 iOS 应用程序 通过 itms-services 协议,发布或者分享 iOS 应用程序 <button onclick="w ...
- 20145227 《Java程序设计》实验五实验报告
20145227 <Java程序设计>实验五实验报告 实验内容 1.掌握Socket程序的编写: 2.掌握密码技术的使用: 3.设计安全传输系统. 实验过程 1.先运行TCP代码,一人服务 ...