2018牛客网暑假ACM多校训练赛(第四场)B Interval Revisited 动态规划
原文链接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 动态规划的更多相关文章
- 2018牛客网暑假ACM多校训练赛(第二场)E tree 动态规划
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round2-E.html 题目传送门 - 2018牛客多校赛第二场 E ...
- 2018牛客网暑假ACM多校训练赛(第三场)I Expected Size of Random Convex Hull 计算几何,凸包,其他
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-I.html 题目传送门 - 2018牛客多校赛第三场 I ...
- 2018牛客网暑假ACM多校训练赛(第三场)G Coloring Tree 计数,bfs
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-G.html 题目传送门 - 2018牛客多校赛第三场 G ...
- 2018牛客网暑假ACM多校训练赛(第三场)D Encrypted String Matching 多项式 FFT
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-D.html 题目传送门 - 2018牛客多校赛第三场 D ...
- 2018牛客网暑假ACM多校训练赛(第十场)H Rikka with Ants 类欧几里德算法
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round10-H.html 题目传送门 - https://www.n ...
- 2018牛客网暑假ACM多校训练赛(第十场)F Rikka with Line Graph 最短路 Floyd
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round10-F.html 题目传送门 - https://www.n ...
- 2018牛客网暑假ACM多校训练赛(第十场)D Rikka with Prefix Sum 组合数学
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round10-D.html 题目传送门 - https://www.n ...
- 2018牛客网暑假ACM多校训练赛(第八场)H Playing games 博弈 FWT
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round8-H.html 题目传送门 - https://www.no ...
- 2018牛客网暑假ACM多校训练赛(第七场)I Tree Subset Diameter 动态规划 长链剖分 线段树
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round7-I.html 题目传送门 - https://www.n ...
- 2018牛客网暑假ACM多校训练赛(第六场)I Team Rocket 线段树
原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round6-I.html 题目传送门 - https://www.no ...
随机推荐
- jquery日常使用总结
1.如何跳出each循环 用 return false, 不是 break. $.each(resArray, function(j, n) { if (1 == n) { return false; ...
- 洛谷P4689 [Ynoi2016]这是我自己的发明 [莫队]
传送门 ynoi中比较良心不卡常的题. 思路 没有换根操作时显然可以变成dfs序莫队随便搞. 换根操作时一个子树可以变成两段区间的并集,也随便搞搞就好了. 这题完全不卡常,随便过. 代码 #inclu ...
- Confluence 6 使用 Fail2Ban 来限制登录尝试
什么是 Fail2Ban? 我们需要在我们网站中防止密码的暴利破解.Fail2Ban 是一个 Python 的应用来查看日志文件,使用的是正则表达式,同时还可以与Shorewall (或者 iptab ...
- Confluence 6 白名单允许进入和禁用
允许进入 启用 CORS 请求,将会从特定的 URL 来源中允许进入(Allow Incoming).URL 格式必须匹配格式 scheme://host[:port],结尾是没有反斜杠的(:port ...
- ionic3 出现莫名广告
应用上线出现 有莫名其妙的广告弹出. 1,DNS被劫持 2,第三方包带广告 3,Http被劫持 wifi和4G网都出现了广告,所以可以直接排除DNS被劫持的问题 广告页只会在H5的页面出现,所以基本可 ...
- mongodb基类封装实例
mongodb的基类 1 <?php 2 3 namespace BI\Service\MongoDB; 4 5 use MongoDB\Driver\BulkWrite; 6 use Mong ...
- nginx+php负载均衡集群环境中的session共享方案梳理
在网站使用nginx+php做负载均衡情况下,同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,就会出现很多问题,比如说最常见的登录状态. 下面罗列几种nginx负载均衡 ...
- NIO(二)
Mark和reset的使用 package com.cppdy.nio; import java.nio.ByteBuffer; //Mark和reset的使用 public class NIOBuf ...
- 【docker】私有仓库搭建
主要参考:http://blog.csdn.net/gqtcgq/article/details/51163558 假设我们在1.1.1.1:5000上搭建私人仓库,并在2.2.2.2上访问这个私人仓 ...
- Winhex数据恢复学习笔记(四)
睡不着,那就深夜写篇笔记打发一下不瞌睡,❥(^_-) 1.winhex在文件批量处理上主要是针对批量保存.打开.关闭,主要还是基于批量打开的其他一些操作,这里通过构造通配符来批量打开,列如 *符号 ? ...