原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round4-B.html

题目传送门 - https://www.nowcoder.com/acm/contest/142/B

题意

  给定 $n$ 条带权线段,第 $i$ 条线段的左右端点坐标分别 $x_i,y_i$ ,权值为 $w_i$ ,坐标范围是 $[1,m]$ 。

  现在让你从这 $n$ 条线段中选择一些线段,要求这些线段能覆盖 $[1,m]$ 中的任何一个整点。

  定义 $f(x)$ 为当前方案中覆盖到坐标 $x$ 的线段的权值和。

  问:对于所有的选择线段的方案,$\max(f(x)|x\in [1,m])$ 的最小值为多少。

  多组数据。

  $n,m\leq 2000,w_i\leq 1000,\sum n\leq 20000$

题解

  讲题人说要线段树??

  直接 $O(nm)$ dp 啊。

  首先我们证明两个结论:

  1.  选出来的线段不存在包含关系。——如果这样的话删掉被包含的那条显然更好

  2.  任何一个点最多被两个线段覆盖。——如果有三条覆盖同一个点,那么一定可以删除其中一条,并满足剩下的线段仍然覆盖所有点。

  这两个性质十分优秀!于是我们就可以 dp 了。

  我们先把所有的线段按照右端点从小到大排序。

  记 $dp_{i,j}$ 表示最右端的一条线段为 $i$ ,上一个线段的结尾的坐标不大于 $j$ 时,$\max(f(x)|x\in [1,m])$ 的最小值 。

  那么,我们对于每一个 $i$ 首先求出所有 上一个线段的结尾的坐标等于 $j$ 时 的 dp 值,然后搞一搞前缀 $\min$ 即可。

  时间复杂度 $O(nm)$ 。

代码

#include <bits/stdc++.h>
using namespace std;
int read(){
int x=0;
char ch=getchar();
while (!isdigit(ch))
ch=getchar();
while (isdigit(ch))
x=(x<<1)+(x<<3)+ch-48,ch=getchar();
return x;
}
const int N=2005;
int n,m,dp[N][N];
struct Segment{
int L,R,w;
}a[N];
bool cmp(Segment a,Segment b){
return a.R<b.R;
}
int main(){
for (int T=read();T;T--){
n=read(),m=read();
for (int i=1;i<=n;i++)
a[i].L=read(),a[i].R=read(),a[i].w=read();
sort(a+1,a+n+1,cmp);
for (int i=0;i<=n;i++)
for (int j=0;j<=m;j++)
dp[i][j]=i==0?0:1e8;
a[0].R=0;
int ans=dp[1][1];
for (int i=1;i<=n;i++){
for (int j=0;j<i;j++){
if (a[j].R+1<a[i].L||a[i].R<=a[j].R)
continue;
int v=dp[j][a[i].L-1];
if (a[j].R>=a[i].L)
v=max(v,a[i].w+a[j].w);
else if (a[j].R+1==a[i].L)
v=max(v,a[i].w);
dp[i][a[j].R]=min(dp[i][a[j].R],v);
}
for (int j=1;j<=m;j++)
dp[i][j]=min(dp[i][j],dp[i][j-1]);
if (a[i].R==m)
ans=min(ans,dp[i][m]);
}
printf("%d\n",ans>=1e8?-1:ans);
}
return 0;
}

  

2018牛客网暑假ACM多校训练赛(第四场)B Interval Revisited 动态规划的更多相关文章

  1. 2018牛客网暑假ACM多校训练赛(第二场)E tree 动态规划

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round2-E.html 题目传送门 - 2018牛客多校赛第二场 E ...

  2. 2018牛客网暑假ACM多校训练赛(第三场)I Expected Size of Random Convex Hull 计算几何,凸包,其他

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-I.html 题目传送门 - 2018牛客多校赛第三场 I ...

  3. 2018牛客网暑假ACM多校训练赛(第三场)G Coloring Tree 计数,bfs

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-G.html 题目传送门 - 2018牛客多校赛第三场 G ...

  4. 2018牛客网暑假ACM多校训练赛(第三场)D Encrypted String Matching 多项式 FFT

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-D.html 题目传送门 - 2018牛客多校赛第三场 D ...

  5. 2018牛客网暑假ACM多校训练赛(第十场)H Rikka with Ants 类欧几里德算法

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round10-H.html 题目传送门 - https://www.n ...

  6. 2018牛客网暑假ACM多校训练赛(第十场)F Rikka with Line Graph 最短路 Floyd

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round10-F.html 题目传送门 - https://www.n ...

  7. 2018牛客网暑假ACM多校训练赛(第十场)D Rikka with Prefix Sum 组合数学

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round10-D.html 题目传送门 - https://www.n ...

  8. 2018牛客网暑假ACM多校训练赛(第八场)H Playing games 博弈 FWT

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round8-H.html 题目传送门 - https://www.no ...

  9. 2018牛客网暑假ACM多校训练赛(第七场)I Tree Subset Diameter 动态规划 长链剖分 线段树

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round7-I.html 题目传送门 -  https://www.n ...

  10. 2018牛客网暑假ACM多校训练赛(第六场)I Team Rocket 线段树

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round6-I.html 题目传送门 - https://www.no ...

随机推荐

  1. 阿里云主机Nginx下配置NodeJS、Express和Forever

    https://cnodejs.org/topic/5059ce39fd37ea6b2f07e1a3 AngularJS中文社区即运行在阿里云主机上,本站使用Nginx引擎,为了AngularJS,我 ...

  2. locale and system laungues

    In computing, a locale is a set of parameters that defines the user's language, region and any speci ...

  3. 前端 ----js的事件流的概念(重要)

    09-JS的事件流的概念(重点)   在学习jQuery的事件之前,大家必须要对JS的事件有所了解.看下文 事件的概念 HTML中与javascript交互是通过事件驱动来实现的,例如鼠标点击事件.页 ...

  4. redhat7.3安装yum源

    #检查rehat自带的yum源[root@localhost ~]# rpm -qa | grep yum -.el7.noarch -.el7.noarch -.el7.noarch -.el7.n ...

  5. python基础教程(第二版)

    开始学习python,根据Python基础教程,把里面相关的基础章节写成对应的.py文件 下面是github上的链接 python基础第1章基础 python基础第2章序列和元组 python基础第3 ...

  6. Oracle12c安装和卸载图文教程

    注:本文来源于:<Oracle12c安装和卸载图文教程> 一.安装 1.去官网下载相应的版本 2.下载好的两个压缩文件压缩到一个文件夹中 3.打开上个步骤的文件夹,运行stepup,显示如 ...

  7. 兼容性很好的纯css圆角

    <!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8& ...

  8. BrupSuite渗透测试笔记(十)

    一.Brup Repeater通常结合Proxy(历史记录),Scanner(扫描记录).Target(站点地图)等,通过其他工具上的右键执行[Send to Repeater],之后跳转到Repea ...

  9. cf581F 依赖背包+临时数组 好题

    这题得加个临时数组才能做.. /* 给定一棵树,树节点可以染黑白,要求叶子节点黑白平分 称连接黑白点的边为杂边,求使得杂边最少的染色方 那么设dp[i][j][0|1]表示i子树中有j个叶子节点,i染 ...

  10. ES6 Promise 全面总结

    转载:点击查看原文 ES6 Promise对象 ES6中,新增了Promise对象,它主要用于处理异步回调代码,让代码不至于陷入回调嵌套的死路中. @-v-@ 1. Promise本质 Promise ...