题意:

建议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的更多相关文章

  1. 【BZOJ4383】[POI2015]Pustynia 线段树优化建图

    [BZOJ4383][POI2015]Pustynia Description 给定一个长度为n的正整数序列a,每个数都在1到10^9范围内,告诉你其中s个数,并给出m条信息,每条信息包含三个数l,r ...

  2. 【bzoj4383】[POI2015]Pustynia 线段树优化建图+差分约束系统+拓扑排序

    题目描述 给定一个长度为n的正整数序列a,每个数都在1到10^9范围内,告诉你其中s个数,并给出m条信息,每条信息包含三个数l,r,k以及接下来k个正整数,表示a[l],a[l+1],...,a[r- ...

  3. 【BZOJ4379】[POI2015]Modernizacja autostrady 树形DP

    [BZOJ4379][POI2015]Modernizacja autostrady Description 给定一棵无根树,边权都是1,请去掉一条边并加上一条新边,定义直径为最远的两个点的距离,请输 ...

  4. 【BZOJ4380】[POI2015]Myjnie 区间DP

    [BZOJ4380][POI2015]Myjnie Description 有n家洗车店从左往右排成一排,每家店都有一个正整数价格p[i].有m个人要来消费,第i个人会驶过第a[i]个开始一直到第b[ ...

  5. 【BZOJ4382】[POI2015]Podział naszyjnika 堆+并查集+树状数组

    [BZOJ4382][POI2015]Podział naszyjnika Description 长度为n的一串项链,每颗珠子是k种颜色之一. 第i颗与第i-1,i+1颗珠子相邻,第n颗与第1颗也相 ...

  6. 【BZOJ4384】[POI2015]Trzy wieże 树状数组

    [BZOJ4384][POI2015]Trzy wieże Description 给定一个长度为n的仅包含'B'.'C'.'S'三种字符的字符串,请找到最长的一段连续子串,使得这一段要么只有一种字符 ...

  7. 【BZOJ4378】[POI2015]Logistyka 树状数组

    [BZOJ4378][POI2015]Logistyka Description 维护一个长度为n的序列,一开始都是0,支持以下两种操作:1.U k a 将序列中第k个数修改为a.2.Z c s 在这 ...

  8. 【BZOJ4385】[POI2015]Wilcze doły 单调栈+双指针法

    [BZOJ4385][POI2015]Wilcze doły Description 给定一个长度为n的序列,你有一次机会选中一段连续的长度不超过d的区间,将里面所有数字全部修改为0.请找到最长的一段 ...

  9. 【BZOJ3747】[POI2015]Kinoman 线段树

    [BZOJ3747][POI2015]Kinoman Description 共有m部电影,编号为1~m,第i部电影的好看值为w[i]. 在n天之中(从1~n编号)每天会放映一部电影,第i天放映的是第 ...

随机推荐

  1. ZBrush中如何做不同图案的遮罩

    ZBrush®软件中不仅可以创建矩形遮罩还可以创建有图案的遮罩,且是非常简单有效的,那么究竟怎样做出神奇的效果,本文将为您详细讲解. 有关反转遮罩.清除遮罩的详细内容,请点击:ZBrush中如何反选遮 ...

  2. IDEA创建Maven工程依赖jar包爆红问题

    使用IDEA创建maven工程后,在pom.xml文件中添加jar包坐标依赖后报错, 如图:

  3. bzoj 3028: 食物 生成函数_麦克劳林展开

    不管怎么求似乎都不太好求,我们试试生成函数.这个东西好神奇.生成函数的精华是两个生成函数相乘,对应 $x^{i}$ 前的系数表示取 $i$ 个时的方案数. 有时候,我们会将函数按等比数列求和公式进行压 ...

  4. 获取浏览器端的cookie方法

    代码如下: function getCookie(key){ var cookies=document.cookie; if(cookies.length>0){ var start=cooki ...

  5. js单体内置对象

    js单体内置对象:js的内置对象,是ECMAScritp提供的.不依赖于宿主环境的对象,我的理解就是在我们开发之前js里面就已经存在的对象.单体内置对象就是是不需要通过new来实例化的,例如我们的st ...

  6. [Atcoder Code Festival 2017 Qual A Problem D]Four Coloring

    题目大意:给一个\(n\times m\)的棋盘染四种颜色,要求曼哈顿距离为\\(d\\)的两个点颜色不同.解题思路:把棋盘旋转45°,则\((x,y)<-(x+y,x-y)\).这样就变成了以 ...

  7. Python 绘图与可视化 seaborn

    Seaborn是一个基于matplotlib的Python数据可视化库.它提供了一个高级界面,用于绘制有吸引力且信息丰富的统计图形. 主页:http://seaborn.pydata.org/ 官方教 ...

  8. ThinkPHP 跨模块调用操作方法(A方法与R方法)

    ThinkPHP 跨模块调用操作方法(A方法与R方法) 跨模块调用操作方法 前面说了可以使用 $this 来调用当前模块内的方法,但实际情况中还经常会在当前模块调用其他模块的方法.ThinkPHP 内 ...

  9. MyBatis学习总结(2)——使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作--基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...

  10. [terry笔记]对人员列表文件进行数据库操作

    原文件(数据已经脱敏): staff_id,name,age,phone,dept,enroll_date1,姬建明,25,152015410,运维,2013-11-012,刘海龙,26,186184 ...