[Poi2012]Festival

时间限制: 1 Sec  内存限制: 64 MB

题目描述

有n个正整数X1,X2,...,Xn,再给出m1+m2个限制条件,限制分为两类:

1. 给出a,b (1<=a,b<=n),要求满足Xa + 1 = Xb

2. 给出c,d (1<=c,d<=n),要求满足Xc <= Xd

在满足所有限制的条件下,求集合{Xi}大小的最大值。

输入

第一行三个正整数n, m1, m2 (2<=n<=600, 1<=m1+m2<=100,000)。

接下来m1行每行两个正整数a,b (1<=a,b<=n),表示第一类限制。

接下来m2行每行两个正整数c,d (1<=c,d<=n),表示第二类限制。

输出

一个正整数,表示集合{Xi}大小的最大值。

如果无解输出NIE。

样例输入

4 2 2

1 2

3 4

1 4

3 1

样例输出

3

提示

|X3=1, X1=X4=2, X2=3

这样答案为3。容易发现没有更大的方案。

  先膜拜一下Q某犇,他给我讲的这道题。

  这道题基本一看就是差分约束,建边已经是套路了,问题在于如何乱搞找出正解。首先,我们可以看出每一个强联通分量对答案的贡献与其他强联通分量无关,因为他们之间建边的话只能是某几个单向的0边,又因为Xi无限制,所以完全是可以对每个强联通分量单独结算在合并的。

  那么我们怎么求在单个强联通分量的最大大小呢?floyd最长路就好了。反正n<=600这道题想卡你的话貌似也不太容易,因此我们大可将每个强联通分量中的点建一个链表,复杂度就大大降低了。

  而有没有接嘛,只要看跑完floyd之后dis[i][i]是否为0就好了。

  

 #include<iostream>
#include<cstdlib>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<map>
#include<queue>
#include<string>
#include<cmath>
#define N 750
using namespace std;
int n,m1,m2;
int zz,dis[N][N];
bool rz[N],rz2[N];
int dfn[N],low[N],st[N],zz2,top;
int be[N],zz3,pre[N];
int mx[N];
void tar(int x){
zz2++;
dfn[x]=low[x]=zz2;
rz[x]=rz2[x]=;
top++;
st[top]=x;
for(int i=;i<=n;i++)
{
if(dis[x][i]!=dis[][]&&i!=x)
{
if(!rz2[i])
{
tar(i);
low[x]=min(low[x],low[i]);
}
else if(rz[i])
{
low[x]=min(low[x],dfn[i]);
}
}
}
if(low[x]==dfn[x])
{
zz3++;
int v,la=;
do{
v=st[top];
top--;
rz[v]=;
if(!be[zz3])
be[zz3]=v;
pre[la]=v;
la=v;
}while(dfn[v]!=low[v]);
}
}
int main(){
memset(pre,-,sizeof(pre));
scanf("%d%d%d",&n,&m1,&m2);
memset(dis,-0xf,sizeof(dis));
for(int i=;i<=m1;i++)
{
int x,y;
scanf("%d%d",&x,&y);
dis[x][y]=max(dis[x][y],);
dis[y][x]=max(-,dis[y][x]);
}
for(int i=;i<=m2;i++)
{
int x,y;
scanf("%d%d",&x,&y);
dis[x][y]=max(dis[x][y],);
}
for(int i=;i<=n;i++)
{
if(!rz2[i])
{
tar(i);
}
} for(int i=;i<=n;i++)
{
dis[i][i]=;
}
for(int o=;o<=zz3;o++)
{
for(int k=be[o];k!=-;k=pre[k])
{
for(int i=be[o];i!=-;i=pre[i])
{
for(int j=be[o];j!=-;j=pre[j])
{
if(abs(dis[i][k])<=n&&abs(dis[k][j])<=n)
dis[i][j]=max(dis[i][j],dis[i][k]+dis[k][j]);
}
}
}
for(int i=be[o];i!=-;i=pre[i])
{
for(int j=be[o];j!=-;j=pre[j])
mx[o]=max(mx[o],abs(dis[i][j]));
}
}
for(int i=;i<=n;i++)
{
if(dis[i][i]!=)
{
printf("NIE\n");
exit();
}
} int ans=;
for(int i=;i<=zz3;i++)
ans+=mx[i]+;
printf("%d\n",ans);
// while(1);
return ;
}

[Poi2012]Festival 题解的更多相关文章

  1. [BZOJ2788][Poi2012]Festival

    2788: [Poi2012]Festival Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 187  Solved: 91[Submit][Statu ...

  2. [Poi2012]Festival 差分约束+tarjan

    差分约束建图,发现要在每个联通块里求最长路,600,直接O(n3) floyed #include<cstdio> #include<cstring> #include< ...

  3. Hdoj 1850.Being a Good Boy in Spring Festival 题解

    Problem Description 一年在外 父母时刻牵挂 春节回家 你能做几天好孩子吗 寒假里尝试做做下面的事情吧 陪妈妈逛一次菜场 悄悄给爸爸买个小礼物 主动地 强烈地 要求洗一次碗 某一天早 ...

  4. [POI2012]Festival

    题目大意: 有$n$个正整数$x_1,x_2,\ldots,x_n$,再给出一些限制条件,限制条件分为两类: 1.给出$A,B$,要求满足$X_A+1=X_B$: 2.给出$C,D$,要求满足$X_C ...

  5. bzoj 2788 [Poi2012]Festival 差分约束+tarjan+floyd

    题目大意 有n个正整数X1,X2,...,Xn,再给出m1+m2个限制条件,限制分为两类: 1.给出a,b (1<=a,b<=n),要求满足Xa + 1 = Xb 2.给出c,d (1&l ...

  6. AT2202 硬度フェスティバル / Kode Festival 题解

    Content 有 \(2^n\) 块石头,第 \(i\) 块石头硬度为 \(a_i\).重复执行以下操作直到只剩下一块石头为止: 让当前编号为 \((1,2)\).\((3,4)\).-- 的石头互 ...

  7. POI2012题解

    POI2012题解 这次的完整的\(17\)道题哟. [BZOJ2788][Poi2012]Festival 很显然可以差分约束建图.这里问的是变量最多有多少种不同的取值. 我们知道,在同一个强连通分 ...

  8. Noip前的大抱佛脚----赛前任务

    赛前任务 tags:任务清单 前言 现在xzy太弱了,而且他最近越来越弱了,天天被爆踩,天天被爆踩 题单不会在作业部落发布,所以可(yi)能(ding)会不及时更新 省选前的练习莫名其妙地成为了Noi ...

  9. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

随机推荐

  1. Win8 Metro(C#)数字图像处理--2.63图像指数增强

    原文:Win8 Metro(C#)数字图像处理--2.63图像指数增强  [函数名称]   指数增强      WriteableBitmap IndexenhanceProcess(Writea ...

  2. 提示Windows Phone IP over USB Transport (IpOverUsbSvc)未运行,如何解决

    原文:提示Windows Phone IP over USB Transport (IpOverUsbSvc)未运行,如何解决 uwp项目在安装测试时提示,"引导"Device&q ...

  3. 零元学Expression Blend 4 - Chapter 7 什麽?影片不再是印象中的方框框!!!看Blend 4如何把影片镶入字里

    原文:零元学Expression Blend 4 - Chapter 7 什麽?影片不再是印象中的方框框!!!看Blend 4如何把影片镶入字里 本章将教大家如何在Blend 4里新增Media El ...

  4. SQLite Expert Professional 打开加密SQLite数据库

    原文 SQLite Expert Professional 打开加密数据库 (已修改) 版本:sqlite expert professional 4.2.0.739 (x86) 目的:用SQLite ...

  5. C# 获取当前月份天数的三种方法总结

    方法一: //最有含量的一种 int days = System.Threading.Thread.CurrentThread.CurrentUICulture.Calendar.GetDaysInM ...

  6. WP8.1的shell:SystemTray去哪了?

    WP8.1 中的SystemTray被 StatusBar 代替了.在Windows.UI.ViewManagement 命名空间下,而且只能在后台代码中设置,XAML中不行.用法是这样的: Stat ...

  7. 解决xp越来越慢的办法(其中有些自动备份的功能)

    1.减少磁盘空间占用2.终止不常用的系统服务3.安全问题4.另外一些技巧 首先问一下,你是不是很想激活XP,不...准确的说你是不是想在ms的站上能够升级.如果答案是肯定的话,那我们就先来探讨一下安装 ...

  8. UI设计师必收!同行总结可即刻上手的iOS规范参考

    分享 <关于我> 分享  [中文纪录片]互联网时代                 http://pan.baidu.com/s/1qWkJfcS 分享 <HTML开发MacOSAp ...

  9. 说说IEnumerable和yield

    IEnumerable数据类型是我比较喜欢的数据类型,特别是其强类型IEnumerable<T>更获得Linq的支持使得代码看起来更加优雅.整洁. 编写返回值为IEnumerable(或I ...

  10. pytorch实现yolov3(2) 配置文件解析及各layer生成

    配置文件 配置文件yolov3.cfg定义了网络的结构 .... [convolutional] batch_normalize=1 filters=64 size=3 stride=2 pad=1 ...