【BZOJ4383】[POI2015]pustynia
题意:
建议Alt+F4百度一下
题解:
差分约束+线段树优化建图,直接按照拓扑序跑就行了
代码:
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define DCSB {printf("NIE");exit(0);}
using namespace std;
struct node{
int ls,rs,v;
}t[];
struct edge{
int v,w,next;
}a[];
int n,m,s,l,r,k,u,v,x,cnt=,rt,tot=,q[],head[],num[],f[],in[];
void add(int u,int v,int w){
a[++tot].v=v;
a[tot].w=w;
a[tot].next=head[u];
head[u]=tot;
in[v]++;
}
void build(int &u,int l,int r){
u=++cnt;
if(l==r){
t[l].v=u;
return;
}
int mid=(l+r)/;
build(t[u].ls,l,mid);
build(t[u].rs,mid+,r);
add(t[u].ls,u,);
add(t[u].rs,u,);
}
void updata(int u,int l,int r,int L,int R,int v){
if(l==L&&r==R){
add(u,cnt,v);
return;
}
int mid=(l+r)/;
if(R<=mid)updata(t[u].ls,l,mid,L,R,v);
else if(L>mid)updata(t[u].rs,mid+,r,L,R,v);
else{
updata(t[u].ls,l,mid,L,mid,v);
updata(t[u].rs,mid+,r,mid+,R,v);
}
}
void topsort(){
int l=,r=;
for(int i=;i<=cnt;i++){
if(!in[i]){
q[++r]=i;
f[i]=;
}
}
while(l<r){
int u=q[++l];
if(f[u]>)DCSB
if(f[u]>num[u]&&num[u]!=)DCSB
f[u]=max(f[u],num[u]);
for(int tmp=head[u];tmp!=-;tmp=a[tmp].next){
int v=a[tmp].v;
in[v]--;
if(!in[v])q[++r]=v;
f[v]=max(f[v],f[u]+a[tmp].w);
}
}
if(r<cnt)DCSB
}
int main(){
memset(head,-,sizeof(head));
scanf("%d%d%d",&n,&s,&m);
build(rt,,n);
for(int i=;i<=s;i++){
scanf("%d%d",&u,&v);
num[t[u].v]=v;
}
for(int i=;i<=m;i++){
scanf("%d%d%d",&l,&r,&k);
l--,cnt++;
for(int j=;j<=k;j++){
scanf("%d",&x);
add(cnt,t[x].v,);
if(l+<x)updata(rt,,n,l+,x-,);
l=x;
}
if(x<r)updata(rt,,n,x+,r,);
}
topsort();
printf("TAK\n");
for(int i=;i<=n;i++)printf("%d ",f[t[i].v]);
return ;
}
【BZOJ4383】[POI2015]pustynia的更多相关文章
- 【BZOJ4383】[POI2015]Pustynia 线段树优化建图
[BZOJ4383][POI2015]Pustynia Description 给定一个长度为n的正整数序列a,每个数都在1到10^9范围内,告诉你其中s个数,并给出m条信息,每条信息包含三个数l,r ...
- 【bzoj4383】[POI2015]Pustynia 线段树优化建图+差分约束系统+拓扑排序
题目描述 给定一个长度为n的正整数序列a,每个数都在1到10^9范围内,告诉你其中s个数,并给出m条信息,每条信息包含三个数l,r,k以及接下来k个正整数,表示a[l],a[l+1],...,a[r- ...
- 【BZOJ4379】[POI2015]Modernizacja autostrady 树形DP
[BZOJ4379][POI2015]Modernizacja autostrady Description 给定一棵无根树,边权都是1,请去掉一条边并加上一条新边,定义直径为最远的两个点的距离,请输 ...
- 【BZOJ4380】[POI2015]Myjnie 区间DP
[BZOJ4380][POI2015]Myjnie Description 有n家洗车店从左往右排成一排,每家店都有一个正整数价格p[i].有m个人要来消费,第i个人会驶过第a[i]个开始一直到第b[ ...
- 【BZOJ4382】[POI2015]Podział naszyjnika 堆+并查集+树状数组
[BZOJ4382][POI2015]Podział naszyjnika Description 长度为n的一串项链,每颗珠子是k种颜色之一. 第i颗与第i-1,i+1颗珠子相邻,第n颗与第1颗也相 ...
- 【BZOJ4384】[POI2015]Trzy wieże 树状数组
[BZOJ4384][POI2015]Trzy wieże Description 给定一个长度为n的仅包含'B'.'C'.'S'三种字符的字符串,请找到最长的一段连续子串,使得这一段要么只有一种字符 ...
- 【BZOJ4378】[POI2015]Logistyka 树状数组
[BZOJ4378][POI2015]Logistyka Description 维护一个长度为n的序列,一开始都是0,支持以下两种操作:1.U k a 将序列中第k个数修改为a.2.Z c s 在这 ...
- 【BZOJ4385】[POI2015]Wilcze doły 单调栈+双指针法
[BZOJ4385][POI2015]Wilcze doły Description 给定一个长度为n的序列,你有一次机会选中一段连续的长度不超过d的区间,将里面所有数字全部修改为0.请找到最长的一段 ...
- 【BZOJ3747】[POI2015]Kinoman 线段树
[BZOJ3747][POI2015]Kinoman Description 共有m部电影,编号为1~m,第i部电影的好看值为w[i]. 在n天之中(从1~n编号)每天会放映一部电影,第i天放映的是第 ...
随机推荐
- uva 11082 Matrix Decompressing 【 最大流 】
只看题目的话~~怎么也看不出来是网络流的题目的说啊~~~~ 建图好神奇~~ 最开始不懂---后来看了一下这篇-- http://www.cnblogs.com/AOQNRMGYXLMV/p/42807 ...
- Unity 设置2台摄像机的叠加
如果Camera1和Camera2拍摄的物体各自在摄像机视野内,如果在同一个屏幕上把2件物体都显示出来? 1,Camera1的Depth设置为-1 2,Camera2的Depth设置为0,同时Clea ...
- Python中一些有用的小命令
1. 查看所有的关键字:help("keywords") 2.查看python所有的modules:help("modules") 3.单看python所有的m ...
- IPv6地址分配
- jQuery $.ajax跨域-JSONP获取JSON数据(转载)
Asynchronous JavaScript and XML (Ajax ) 是驱动新一代 Web 站点(流行术语为 Web 2.0 站点)的关键技术.Ajax 允许在不干扰 Web 应用程序的显示 ...
- struts2配置 匹配原则 配置各项默认
struts开发流程 1,引入jar包 2,配置web.xml 3,开发action类 4,配置struts.xml 版本: 2.3 引入jar文件 commons-fileupload-1.2. ...
- Day 07 数据类型的内置方法[列表,元组,字典,集合]
数据类型的内置方法 一:列表类型[list] 1.用途:多个爱好,多个名字,多个装备等等 2.定义:[]内以逗号分隔多个元素,可以是任意类型的值 3.存在一个值/多个值:多个值 4.有序or无序:有序 ...
- Day 02 - 02 编程语言的分类
编程语言的分类 机器语言分为: 1.机器语言 优点:执行代码效率非常快 缺点:开发效率低 2.汇编语言 优点(相对于机器语言):开发效率高 缺点(相对于机器语言):执行效率低 3.高级语言 解释型(同 ...
- 关于fromkeys的用法
分享一个小知识点: 1. Python 中关于dict的fromkeys方法: 1. fromkeys是用于重构字典 2. 至少传一个参数,第一个参数为新建dict的key,如果第一个参数为字典,那么 ...
- jquery中的jsonp跨域调用(接口)
jquery jsonp跨域调用接口