【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天放映的是第 ...
随机推荐
- Unity 已下载工程包存放路径
Mac Finder 中 Shift+Command+G输入后回车 ~/Library/Unity/Asset Store-5.x Windows 么有,自己上别的网站查去~
- Pyhton学习——Day36
#异步IO——Asynchronous#异步效率最高,特点:全程无阻塞# 在说明synchronous IO和asynchronous IO的区别之前,需要先给出两者的定义.# Stevens给出的定 ...
- mySql 使用 SQL 文件脚本 failed to open file 注意事项
1.路径不要有中文,其实最好是全英文 2.路径可以有空格 3.路径两头不要加引号 4.作为一个MySQL命令,source C:/lib/a.sql; 后边的分号是要的. 5.使用 unix 路径风格 ...
- [CTSC1999][网络流24题]家园
题目:洛谷P2754. 题目大意:有$n$个空间站,$m$个飞船,每个飞船有各自的停靠站点,并且从第一个停靠站点开始,不断循环.每个飞船有不同的容量(-1为月球,0为地球).每个飞船初始停在第一个停靠 ...
- [读书笔记] R语言实战 (六) 基本图形方法
1. 条形图 barplot() #载入vcd包 library(vcd) #table函数提取各个维度计数 counts <- table(Arthritis$Improved) count ...
- Myeclipse关闭JS等文件的验证
点击 window > 右键单击properties,弹出properties界面 然后选择MyEclipse->validation->Excluded Resource下找到不需 ...
- js实现导航固定定位
js实现导航固定定位 <!DOCTY ...
- java中的instanceof用法
Java 中的instanceof 运算符是用来在运行时指出对象是否是特定类的一个实例.instanceof通过返回一个布尔值来指出,这个对象是否是这个特定类或者是它的子类的一个实例. 用法: ...
- md5如何实现encodePassword加密方法
后台的加密代码:用户名:zhangsan 密码:123 /** * 编译密码,即加密 * @param user 用户信息 * @param password 密码 * @return 返回值为加 ...
- Java基础学习总结(33)——Java8 十大新特性详解
Java8 十大新特性详解 本教程将Java8的新特新逐一列出,并将使用简单的代码示例来指导你如何使用默认接口方法,lambda表达式,方法引用以及多重Annotation,之后你将会学到最新的API ...