POJ - 1201 Intervals (最短路解线性规划)
相交区间选尽量少的点是可以贪心的,右端点排序以后,尽量往右边放可以得到可以使得点在区间尽可能多。
但是我只想到了O(n)的维护方法。(数据比较水,能过...
或者是前缀和可以写sum(bi) - sum(ai-1) ≥ ci
再加上前缀和的单调性 sum(i) - sum(i-1) ≥ 0
以及一个点只能选一次 sum(i-1) - sum(i) ≥ -1。
左边具有可加性的,根据对偶性:min ( sum(n) - sum(0) ) ≥ max( c )
右边就是求一个最长路了。
复杂度:O(VE)。
两种复杂度都爆了,还是能过,大力出奇迹。。。
- #include<cstdio>
- #include<iostream>
- #include<string>
- #include<cstring>
- #include<queue>
- #include<vector>
- #include<stack>
- #include<vector>
- #include<map>
- #include<set>
- #include<algorithm>
- #include<cmath>
- #include<numeric>
- using namespace std;
- typedef long long ll;
- const int maxn = +;
- const int maxm = maxn*;
- int dat[][maxn];
- int * const d = dat[]+;
- int * const hd = dat[]+;
- int nx[maxm];
- int a[maxn], b[maxm], c[maxm];
- int ec;
- void add_edge(int u, int v, int w)
- {
- c[ec] = w;
- b[ec] = v;
- nx[ec] = hd[u];
- hd[u] = ec++;
- }
- int n;
- int q[maxn];
- bool inq[maxn];
- int spfa(int s, int t)
- {
- memset(d+s,0xff,sizeof(int)*(t-s+));
- int top = ;
- q[++top] = s; d[s] = ; inq[s] = true;
- while(top){
- int u = q[top--];
- inq[u] = false;
- for(int i = hd[u]; ~i; i = nx[i]){
- int v = b[i];
- if(d[v] < d[u] + c[i]){
- d[v] = d[u] + c[i];
- if(!inq[v]) {
- q[++top] = v;
- inq[v] = true;
- }
- }
- }
- }
- return d[t];
- }
- void solve()
- {
- for(int i = ; i < n; i++){
- scanf("%d%d%d", a+i, b+i, c+i);
- }
- int s = *min_element(a,a+n)-, t = *max_element(b,b+n);
- memset(hd+s, 0xff, sizeof(int)*(t-s+));
- for(int i = ; i < n; i++){
- nx[i] = hd[--a[i]];
- hd[a[i]] = i;
- }
- ec = n;
- for(int i = s; i < t; i++){
- add_edge(i,i+,);
- add_edge(i+,i,-);
- }
- printf("%d\n", spfa(s,t));
- }
- //#define LOCAL
- int main()
- {
- #ifdef LOCAL
- freopen("in.txt","r",stdin);
- #endif
- while(~scanf("%d",&n)){
- solve();
- }
- return ;
- }
POJ - 1201 Intervals (最短路解线性规划)的更多相关文章
- poj 1201 Intervals 解题报告
Intervals Time Limit: 2000MS Memory Limit: 65536KB 64bit IO Format: %lld & %llu Submit Statu ...
- POJ 1201 Intervals || POJ 1716 Integer Intervals 差分约束
POJ 1201 http://poj.org/problem?id=1201 题目大意: 有一个序列,题目用n个整数组合 [ai,bi,ci]来描述它,[ai,bi,ci]表示在该序列中处于[ai, ...
- POJ 1201 Intervals (差分约束,最短路)
题意: 有一个集合Z,其元素都是整整数,但是数量未知.现有n个约束,形如 [a,b]=c 表示整数区间[a,b]中有c个元素在Z中出现.问集合Z最小可能含多少个元素? 思路: 对于所给的区间 cnt[ ...
- poj 1201 Intervals(差分约束)
做的第一道差分约束的题目,思考了一天,终于把差分约束弄懂了O(∩_∩)O哈哈~ 题意(略坑):三元组{ai,bi,ci},表示区间[ai,bi]上至少要有ci个数字相同,其实就是说,在区间[0,500 ...
- poj 1201 Intervals(差分约束)
题目:http://poj.org/problem?id=1201 题意:给定n组数据,每组有ai,bi,ci,要求在区间[ai,bi]内至少找ci个数, 并使得找的数字组成的数组Z的长度最小. #i ...
- poj 1201 Intervals——差分约束裸题
题目:http://poj.org/problem?id=1201 差分约束裸套路:前缀和 本题可以不把源点向每个点连一条0的边,可以直接把0点作为源点.这样会快许多! 可能是因为 i-1 向 i 都 ...
- POJ 1201 Intervals【差分约束】
传送门:http://poj.org/problem?id=1201 题意: 有n个如下形式的条件:,表示在区间[, ]内至少要选择个整数点.问你满足以上所有条件,最少需要选多少个点? 思路:第一道差 ...
- POJ 1201 Intervals (差分约束系统)
题意 在区间[0,50000]上有一些整点,并且满足n个约束条件:在区间[ui, vi]上至少有ci个整点,问区间[0, 50000]上至少要有几个整点. 思路 差分约束求最小值.把不等式都转换为&g ...
- POJ 1201 Intervals(图论-差分约束)
Intervals Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 20779 Accepted: 7863 Descri ...
随机推荐
- select随笔
粘贴下面代码 select 美化 <!doctype html> <html lang="en"> <head> <meta charse ...
- Python 错误总结
1.以一种访问权限不允许的方式做了一个访问套接字的尝试. 解决方法:这个问题缘由是有端口被占用
- 匿名类与lambda区别
第一种是继承Thread, 重写了Thread.run() getClass()返回的是匿名类 java.long.Thread$1 第二种是lambda, 重写了Runnable.run() ...
- JS时间控件 moment.js用法
参考http://momentjs.cn/ 下载 moment.js moment.min.js 12.4k moment+多语言支持.js moment+多语言支持.min.js 45.4k 安装 ...
- Java 实践
/** *宠物就是一个标准,包含多类宠物 *定义宠物标准接口Pet *定义Cat和Dog两个Pet接口的子类 *使用链表结构动态存储宠物信息 *定义商店类(工厂类),负责宠物的上架(链表添加).下架( ...
- 局部安装webpack时,使用webpack命令时提示webpack不是内部命令解决方法
现在js发展太快了,根本看不懂啊.于是乎想做做功课,于是乎看到了这些“奇怪”的写法,原来好多都是遵循了 ECMASCRIPT6,好吧,在本地看看怎么用的吧.写在本地的环境下, 发现各种报错,根本不能用 ...
- Codecraft-18 and Codeforces Round #458 (Div. 1 + Div. 2, combined) F. Substrings in a String
http://codeforces.com/contest/914/problem/F 以前做过一个类似的,但是查询的子串长度最多是10,这个时候就是用bit + hash做了.这是因为改变一个字符, ...
- PHP文件访问
文件和目录处理函数 basename — 返回路径中的文件名部分 | Returns trailing name component of path | chgrp — 改变文件所属的组 | Chan ...
- [转]AngularJS 使用 UI Router 实现表单向导
本文转自:http://www.oschina.net/translate/angularjs-multi-step-form-using-ui-router 今天我们将使用AngularJs和伟大的 ...
- Python 元组 (tuple)
作者博文地址:https://www.cnblogs.com/liu-shuai/ Python的元组与列表类似,同样可通过索引访问,支持异构,任意嵌套.不同之处在于元组的元素不能修改.元组使用小括号 ...