Intervals
时间:2019-09-23
本文章向大家介绍Intervals,主要包括Intervals使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
POJ
洛咕-UVA
洛咕-SP
题意:有\(n(n<=50000)\)个区间,在区间\([a_i,b_i](0<=a_i,b_i<=50000)\)中至少取任意互不相同的\(c_i\)个整数.求在满足n个区间的情况下,至少要取多少个正整数?
分析:差分约束.设\(s[k]\)表示0到k之间最少选出多少个整数.则对于每个区间的限制条件可以看成是\(s[b_i]-s[a_i-1]>=c_i\),这样就是差分约束的模型了,我们在\(a_i-1,b_i\)之间连一条长度为\(c_i\)的有向边(实际代码中我连得是\(a_i,b_i+1\),一个意思.)
然后结合\(s\)数组的定义,\(s[k]-s[k-1]>=0\),所以\(k-1,k\)之间连一条长度为0的有向边,\(s[k]-s[k-1]<=1\)可以看做\(s[k-1]-s[k]>=-1\),所以\(k,k-1\)之间连一条长度为-1的有向边.
建图之后,就可以跑最长路了.题目保证\(1<=c_i<=b_i-a_i+1\),所以不会出现正环.
最长路的起点就是\(min_{a_i}\),终点就是\(max_{b_i}.\)
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#include<map>
#include<set>
#define ll long long
using namespace std;
inline int read(){
int x=0,o=1;char ch=getchar();
while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
if(ch=='-')o=-1,ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x*o;
}
const int N=200005;
int n,minn,maxn,dis[N],visit[N];
int tot,head[N],nxt[N],to[N],w[N];
inline void add(int a,int b,int c){
nxt[++tot]=head[a];head[a]=tot;
to[tot]=b;w[tot]=c;
}
queue<int>q;
inline void spfa(){
for(int i=minn;i<=maxn;++i)dis[i]=-1e9;//最长路,所以赋值无穷小
q.push(minn);dis[minn]=0;visit[minn]=1;
while(q.size()){
int u=q.front();q.pop();visit[u]=0;
for(int i=head[u];i!=-1;i=nxt[i]){
int v=to[i];
if(dis[v]<dis[u]+w[i]){//注意是最长路
dis[v]=dis[u]+w[i];
if(!visit[v]){
visit[v]=1;
q.push(v);
}
}
}
}
}
int main(){
int T=read();
while(T--){
tot=0;memset(head,-1,sizeof(head));//多组数据初始化,因为有可能起点是0号点,所以head设为-1
minn=1e9,maxn=-1e9;n=read();
for(int i=1;i<=n;++i){
int a=read(),b=read(),c=read();
add(a,b+1,c);
minn=min(minn,a);//编号最小是起点
maxn=max(maxn,b+1);//编号最大是终点
}
for(int i=minn;i<maxn;++i){
add(i,i+1,0);add(i+1,i,-1);
}
spfa();
printf("%d\n",dis[maxn]);
if(T)puts("");
}
return 0;
}
原文地址:https://www.cnblogs.com/PPXppx/p/11573257.html
- 进入AI时代,你准备好了吗?
- TiDB 在 G7 的实践和未来
- 投资钛值的你,知道钛链是什么吗?
- Is this a MS EnterLib DAAB BUG or not?
- Silverlight 2 has a Timer (DispatcherTimer)
- 难道调用ThreadPool.QueueUserWorkItem()的时候,真是必须调用Thread.Sleep(N)吗?
- silverlight 《Hands-On-Labs》教程系列
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(67)-MVC与ECharts
- 2018年机器学习和数据科学重要会议概览
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(60)-系统总结
- WCF技术剖析之一:通过一个ASP.NET程序模拟WCF基础架构
- 使用动态语言来制作silverlight
- 《资讯》霍金:人工智能的威胁就像核武器,世界将发生10大变化!
- [原创]WCF技术剖析之三:如何进行基于非HTTP的IIS服务寄宿
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- [Go]GO语言实战-GO-FLY在线客服cobra库命令行参数解析
- [Go]GO语言实战-GO-FLY在线客服gorm导入sql文件
- Day7.数据类型-集合
- 详解一条查询select语句和更新update语句的执行流程
- JSP 开发环境搭建与项目运行(二)
- Activity启动时生命周期汇总
- 「程序员」Flutter:从网络获取数据遇到的坑
- 程序员:拿到新电脑如何配置Git环境
- What?数据量巨大还不分库分表?JDBC 入门与项目实战
- 简书:如何去掉图片下面烦人的“图片发自简书App”
- 命令行shell复制并以当前时间重命名文件夹
- 如何获取PHP命令行参数
- 学习PHP弱引用的知识
- 「okhttp」Gradle引用改jar包引用(一波三折)
- 「问答」解决CSV文件用Excel打开乱码问题