hdu 4940 Destroy Transportation system (无源汇上下界可行流)
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
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.
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.
number starting from 1.If such set doesn’t exist, print “happy”, else print
“unhappy”.
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 (无源汇上下界可行流)的更多相关文章
- HDU 4940 Destroy Transportation system(无源汇上下界网络流)
Problem Description Tom is a commander, his task is destroying his enemy’s transportation system. Le ...
- hdu 4940 Destroy Transportation system( 无源汇上下界网络流的可行流推断 )
题意:有n个点和m条有向边构成的网络.每条边有两个花费: d:毁坏这条边的花费 b:重建一条双向边的花费 寻找这样两个点集,使得点集s到点集t满足 毁坏全部S到T的路径的费用和 > 毁坏全部T到 ...
- ZOJ 2314 - Reactor Cooling - [无源汇上下界可行流]
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2314 The terrorist group leaded by ...
- zoj 2314 Reactor Cooling (无源汇上下界可行流)
Reactor Coolinghttp://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1314 Time Limit: 5 Seconds ...
- ZOJ2314 Reactor Cooling(无源汇上下界可行流)
The terrorist group leaded by a well known international terrorist Ben Bladen is buliding a nuclear ...
- zoj2314 无源汇上下界可行流
题意:看是否有无源汇上下界可行流,如果有输出流量 题解:对于每一条边u->v,上界high,下界low,来说,我们可以建立每条边流量为high-low,那么这样得到的流量可能会不守恒(流入量!= ...
- 有源汇上下界可行流(POJ2396)
题意:给出一个n*m的矩阵的每行和及每列和,还有一些格子的限制,求一组合法方案. 源点向行,汇点向列,连一条上下界均为和的边. 对于某格的限制,从它所在行向所在列连其上下界的边. 求有源汇上下界可行流 ...
- 计蒜客 31447 - Fantastic Graph - [有源汇上下界可行流][2018ICPC沈阳网络预赛F题]
题目链接:https://nanti.jisuanke.com/t/31447 "Oh, There is a bipartite graph.""Make it Fan ...
- poj2396有源汇上下界可行流
题意:给一些约束条件,要求算能否有可行流,ps:刚开始输入的是每一列和,那么就建一条上下界相同的边,这样满流的时候就一定能保证流量相同了,还有0是该列(行)对另一行每个点都要满足约束条件 解法:先按无 ...
随机推荐
- Windows 10 系统下Python环境的搭建与配置
1. 在https://www.python.org/downloads/release/python-352/网站上下载python版本 2. 配置环境 右击计算机属性,然后选择高级系统设置 3. ...
- windows+ubuntu时间修改问题
只需要在ubuntu系统数输入一行指令即可 timedatectl set-local-rtc 1 --adjust-system-clock
- DescriptionAttribute Class
指定属性或事件的描述. [Description("The image associated with the control"),Category("Appearanc ...
- Alpha-8
前言 失心疯病源8 团队代码管理github 站立会议 队名:PMS 530雨勤(组长) 今天完成了那些任务 20:00~23:00 代码整合,已形成可用模块,但还需适应场景局部优化 代码签入gith ...
- lintcode-392-打劫房屋
392-打劫房屋 假设你是一个专业的窃贼,准备沿着一条街打劫房屋.每个房子都存放着特定金额的钱.你面临的唯一约束条件是:相邻的房子装着相互联系的防盗系统,且 当相邻的两个房子同一天被打劫时,该系统会自 ...
- 可以从Jar外部加载JDBC.properties的Spring-mybatis配置文件
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- linux mysql表名大小写
1.用ROOT登录,修改/etc/my.cnf 2.在[mysqld]下加入一行:lower_case_table_names=1 0:区分大小写,1:不区分大小写 3.重新启动数据库即可
- web移动开发最佳实践之js篇
一.js概述 js即JavaScript,是被设计用来验证表单.检测浏览器.创建cookies.改进设计以及更多应用的网络脚本语言,它非常容易使用.在web应用中,它是主要的编程语言,主要用途是进行各 ...
- bzoj1390 [CEOI2008] Fence
题意 给出n个白点和m个黑点.现在你需要选择一些白点把黑点圈起来.每有一个黑点不能被选出的白点组成的凸包包含就需要付出111的代价,每选出一个白点就需要付出20的代价.要求最小化代价之和 n,m< ...
- BZOJ4985 评分(二分答案+树形dp)
首先二分答案简化一下问题,现在只有0和1了,要求最后剩下的是1.再简化一下考虑没有已固定的位置怎么做.考虑每个位置由其合并到的位置连边,显然这样形成了一棵三叉树.设f[i]为使得某位置为1其子树至少要 ...