Destroy Transportation system

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)
http://acm.hdu.edu.cn/showproblem.php?pid=4940

Problem Description
Tom is a commander, his task is destroying his enemy’s
transportation system.

Let’s represent his enemy’s transportation system
as a simple directed graph G with n nodes and m edges. Each node is a city and
each directed edge is a directed road. Each edge from node u to node v is
associated with two values D and B, D is the cost to destroy/remove such edge, B
is the cost to build an undirected edge between u and v.

His enemy can
deliver supplies from city u to city v if and only if there is a directed path
from u to v. At first they can deliver supplies from any city to any other
cities. So the graph is a strongly-connected graph.

He will choose a
non-empty proper subset of cities, let’s denote this set as S. Let’s denote the
complement set of S as T. He will command his soldiers to destroy all the edges
(u, v) that u belongs to set S and v belongs to set T.

To destroy an
edge, he must pay the related cost D. The total cost he will pay is X. You can
use this formula to calculate X:

After that, all the edges from S to
T are destroyed. In order to deliver huge number of supplies from S to T, his
enemy will change all the remained directed edges (u, v) that u belongs to set T
and v belongs to set S into undirected edges. (Surely, those edges exist because
the original graph is strongly-connected)

To change an edge, they must
remove the original directed edge at first, whose cost is D, then they have to
build a new undirected edge, whose cost is B. The total cost they will pay is Y.
You can use this formula to calculate Y:

At last, if Y>=X, Tom will
achieve his goal. But Tom is so lazy that he is unwilling to take a cup of time
to choose a set S to make Y>=X, he hope to choose set S randomly! So he asks
you if there is a set S, such that Y<X. If such set exists, he will feel
unhappy, because he must choose set S carefully, otherwise he will become very
happy.

 
Input
There are multiply test cases.

The first line
contains an integer T(T<=200), indicates the number of cases.

For
each test case, the first line has two numbers n and m.

Next m lines
describe each edge. Each line has four numbers u, v, D, B.
(2=<n<=200,
2=<m<=5000, 1=<u, v<=n, 0=<D, B<=100000)

The meaning of
all characters are described above. It is guaranteed that the input graph is
strongly-connected.

 
Output
For each case, output "Case #X: " first, X is the case
number starting from 1.If such set doesn’t exist, print “happy”, else print
“unhappy”.
 
Sample Input
2
3 3
1 2 2 2
2 3 2 2
3 1 2 2
3 3
1 2 10 2
2 3 2 2
3 1 2 2
 
Sample Output
Case #1: happy
Case #2: unhappy
 
Hint

In first sample, for any set S, X=2, Y=4. In second sample. S= {1}, T= {2, 3}, X=10, Y=4.

 
题意:给出一个有向强连通图,每条边有两个值:破坏该边的代价a 和 把该边建成无向边的代价b
问是否存在一个集合S和S的补集T,满足 S到T的割边的 a的总和 > T到S的 割边的 a+b的总和
若存在 输出unhappy, 不存在,输出happy 以a为下界,a+b为上界,判断是否存在无源汇上下界可行流
因为如果存在,流量总和>=下界,<=上界
#include<cstdio>
#include<cstring>
#include<queue>
#include<algorithm>
#define N 210
#define M 15000
using namespace std;
int m,n,src,dec,sum,tot;
int a[N];
int front[N],to[M],nextt[M],cap[M];
int lev[N],cur[N];
queue<int>q;
void add(int u,int v,int w)
{
to[++tot]=v; nextt[tot]=front[u]; front[u]=tot; cap[tot]=w;
to[++tot]=u; nextt[tot]=front[v]; front[v]=tot; cap[tot]=;
}
bool bfs()
{
for(int i=src;i<=dec;i++) cur[i]=front[i],lev[i]=-;
while(!q.empty()) q.pop();
lev[src]=;
q.push(src);
int now;
while(!q.empty())
{
now=q.front(); q.pop();
for(int i=front[now];i;i=nextt[i])
if(cap[i]>&&lev[to[i]]==-)
{
lev[to[i]]=lev[now]+;
if(to[i]==dec) return true;
q.push(to[i]);
}
}
return false;
}
int dfs(int now,int flow)
{
if(now==dec) return flow;
int rest=,delta;
for(int & i=cur[now];i;i=nextt[i])
if(cap[i]>&&lev[to[i]]>lev[now])
{
delta=dfs(to[i],min(flow-rest,cap[i]));
if(delta)
{
cap[i]-=delta; cap[i^]+=delta;
rest+=delta; if(rest==flow) break;
}
}
if(rest!=flow) lev[now]=-;
return rest;
}
int dinic()
{
int tmp=;
while(bfs()) tmp+=dfs(src,2e9);
return tmp;
}
int main()
{
int T;
scanf("%d",&T);
for(int k=;k<=T;k++)
{
memset(a,,sizeof(a));
memset(front,,sizeof(front));
sum=; tot=;
scanf("%d%d",&n,&m);
src=; dec=n+;
int u,v,c,d;
for(int i=;i<=m;i++)
{
scanf("%d%d%d%d",&u,&v,&c,&d);
a[v]+=c; a[u]-=c;
add(u,v,d);
}
for(int i=;i<=n;i++)
if(a[i]<) add(i,dec,-a[i]);
else if(a[i]>) {add(src,i,a[i]); sum+=a[i];}
if(dinic()==sum) printf("Case #%d: happy\n",k);
else printf("Case #%d: unhappy\n",k);
}
}
 

hdu 4940 Destroy Transportation system (无源汇上下界可行流)的更多相关文章

  1. HDU 4940 Destroy Transportation system(无源汇上下界网络流)

    Problem Description Tom is a commander, his task is destroying his enemy’s transportation system. Le ...

  2. hdu 4940 Destroy Transportation system( 无源汇上下界网络流的可行流推断 )

    题意:有n个点和m条有向边构成的网络.每条边有两个花费: d:毁坏这条边的花费 b:重建一条双向边的花费 寻找这样两个点集,使得点集s到点集t满足 毁坏全部S到T的路径的费用和 > 毁坏全部T到 ...

  3. ZOJ 2314 - Reactor Cooling - [无源汇上下界可行流]

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2314 The terrorist group leaded by ...

  4. zoj 2314 Reactor Cooling (无源汇上下界可行流)

    Reactor Coolinghttp://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1314 Time Limit: 5 Seconds ...

  5. ZOJ2314 Reactor Cooling(无源汇上下界可行流)

    The terrorist group leaded by a well known international terrorist Ben Bladen is buliding a nuclear ...

  6. zoj2314 无源汇上下界可行流

    题意:看是否有无源汇上下界可行流,如果有输出流量 题解:对于每一条边u->v,上界high,下界low,来说,我们可以建立每条边流量为high-low,那么这样得到的流量可能会不守恒(流入量!= ...

  7. 有源汇上下界可行流(POJ2396)

    题意:给出一个n*m的矩阵的每行和及每列和,还有一些格子的限制,求一组合法方案. 源点向行,汇点向列,连一条上下界均为和的边. 对于某格的限制,从它所在行向所在列连其上下界的边. 求有源汇上下界可行流 ...

  8. 计蒜客 31447 - Fantastic Graph - [有源汇上下界可行流][2018ICPC沈阳网络预赛F题]

    题目链接:https://nanti.jisuanke.com/t/31447 "Oh, There is a bipartite graph.""Make it Fan ...

  9. poj2396有源汇上下界可行流

    题意:给一些约束条件,要求算能否有可行流,ps:刚开始输入的是每一列和,那么就建一条上下界相同的边,这样满流的时候就一定能保证流量相同了,还有0是该列(行)对另一行每个点都要满足约束条件 解法:先按无 ...

随机推荐

  1. c# 免费版pdf转word尝试

    链接:https://pan.baidu.com/s/1Dwuezo6YGe9CdlSyrwQyNg 密码:c81a 1.安装此程序 2.在安装文件的bin下拷贝dll: 3.代码引用 private ...

  2. 简评搜狗输入法(ios端)

    首先说说为什么不使用iPhone自带的输入法呢,首先是词库不够丰富,好多简单的词语需要逐个字逐个字的选择,记忆功能不太好,其次是全键盘式的输入我不太习惯,还是九宫格的输入法比较简单,更方便快捷. 搜狗 ...

  3. 第一次c++团队合作项目第二篇随笔

    随着时间的推移,项目也逐渐展开.我的地图也通过按钮的拼接完成了一小部分.这部分我是用了QT上的按钮类来实现的.接下来就是给按钮贴上图片,然后最重要也是最困难的是实现参数的传递,如何实现点击一个英雄或小 ...

  4. 读<<我是IT小小鸟>>

    <倔强><怒放的生命>以歌曲的含义来引入文章,让文章可以与音乐产生共鸣让读者可以直接明了的就直击到本篇文章的中心含义是非常受用的,在文中写了许多以自己为视角,以自己的成长经历来 ...

  5. virtualbox 5.0.6 在debian jessie amd64启动报错

    通过dmesg发现vboxdrv启动报错: [ 18.844888] systemd[1]: [/lib/systemd/system/vboxdrv.service:5] Failed to add ...

  6. 删除多余的自编译的内核、mysql连接不了的问题

    1.删除多余的自编译的内核 每次Debian发布内核更新,总是有某些内核选项跟自己的硬件不配套,要自己编译内核.编译多了,多余的内核就占用了多余的硬盘空间.我就试过因为/boot分区满了,而导致编译内 ...

  7. PDO笔记

    <?php/* * 查询操作主要是PDO::query().PDO::exec().PDO::prepare().PDO::query()主要是用于有记录结果返回的操作,特别是SELECT操作, ...

  8. Distributed transactions in Spring, with and without XA

    While it's common to use the Java Transaction API and the XA protocol for distributed transactions i ...

  9. HSF源码剖析

    前言 HSF是一个分布式的远程服务调用框架,其实我更喜欢把分布式几个字去掉,因为HSF本身并不是一个单独的服务(指一个进程),他是附属在你的应用里的一个组件,一个RPC组件(远程过程调用——Remot ...

  10. fiddler启动报错Unable to bind to port [8888],ErrorCode:10106

    启动运行fiddler 报错,提示Unable to bind to port [8888],ErrorCode:10106 解决方式: 使用Fiddler或其他类似的监听工具出现这种错误时, Una ...