博客
关于我
POJ - 1201 Intervals差分约束
阅读量:690 次
发布时间:2019-03-17

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

题目大意

给定n个区间, 求选择若干个数, 保证每个区间中选择的数不少于c

思路

根据题目的条件写出不等式
在这里插入图片描述

  • 在建图时, 由于用到了前缀合, 我们额a,b的取值范围增加1, 把取值范围变为1~50001
  • 最后dis[50001]里面存的就是本题的答案
  • 由于数据保证了c<=b-a+1, 所以本题一定有解
#include 
#include
#include
#include
using namespace std;const int N = 50010, M = 150010;int e[M], ne[M], w[M], h[N], len;int n;int dis[N];bool vis[N];void add(int a, int b, int c){ e[len] = b; w[len] = c; ne[len] = h[a]; h[a] = len++;}void spfa(){ memset(dis, -0x3f, sizeof dis); queue
q; q.push(0); dis[0] = 0; vis[0] = true; while(q.size()) { int x = q.front(); q.pop(); vis[x] = false; for(int i = h[x]; ~i; i = ne[i]) { int y = e[i]; if(dis[y] < dis[x] + w[i]) { dis[y] = dis[x] + w[i]; if(!vis[y]) { q.push(y); vis[y] = true; } } } } }int main(){ cin >> n; memset(h, -1, sizeof h); for(int i = 1; i<= n; i++) { int a, b, c; scanf("%d%d%d", &a, &b, &c); a ++, b++; add(a - 1, b, c); } for(int i = 1; i <= 50001; i++) add(i - 1, i, 0), add(i, i - 1, -1); spfa(); printf("%d", dis[50001]); return 0;}

转载地址:http://gxihz.baihongyu.com/

你可能感兴趣的文章
NAT-DDNS内网穿透技术,快解析DDNS的优势
查看>>
NAT-DDNS内网穿透技术,解决动态域名解析难题
查看>>
natapp搭建外网服务器
查看>>
NativePHP:使用PHP构建跨平台桌面应用的新框架
查看>>
nativescript(angular2)——ListView组件
查看>>
NativeWindow_01
查看>>
Native方式运行Fabric(非Docker方式)
查看>>
Nature | 电子学“超构器件”, 从零基础到精通,收藏这篇就够了!
查看>>
Nature和Science同时报道,新疆出土四千年前遗骸完成DNA测序,证实并非移民而是土著...
查看>>
Nature封面:只低一毫米,时间也会变慢!叶军团队首次在毫米尺度验证广义相对论...
查看>>
Nat、端口映射、内网穿透有什么区别?
查看>>
Nat、端口映射、内网穿透有什么区别?
查看>>
nat打洞原理和实现
查看>>
NAT技术
查看>>
NAT模式/路由模式/全路由模式 (转)
查看>>
NAT模式下虚拟机centOs和主机ping不通解决方法
查看>>
NAT的两种模式SNAT和DNAT,到底有啥区别?
查看>>
NAT的全然分析及其UDP穿透的全然解决方式
查看>>
NAT类型与NAT模型详解
查看>>
NAT网络地址转换配置实战
查看>>