Coding Contest HDU - 5988(费用流)
题意:
有n个区域和m条路,每个区域有a[i]个人和b[i]个食物,然后是m条路连接两个区域,这条路容量为cap,这条路断掉的概率为p,第一个经过的时候一定不会断,后面的人有概率p会断,现在需要所有人都吃上饭并且破坏网络的概率最小
解析:
多源多汇,建一个超级源指向食物多的 超级汇指向人多的 概率为价值 板子里的价值都是加 所以化成log形式就好了 最后在化回来
求的是最小被破坏的概率,那么1 - 最大被破坏的概率就好了 费用流是价值最小 给价值加个符号 不就是最大了嘛
代码来自 :https://blog.csdn.net/Nemaleswang/article/details/77870967
改成了我喜欢写的形式,为什么不贴我的。。。。。emm。。。明明写的好看。。。为啥我的T
生活失去了希望
#include <map>
#include <set>
#include <cmath>
#include <queue>
#include <stack>
#include <vector>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm> using namespace std;
const int INF = 0x3f3f3f3f;
const int maxn = ;
const int MaxEdge = ;
const double eps = 1e-;
int max_flow;
double value;
struct Edge{
int to,vol,next;
double cost;
}Node[MaxEdge]; int Pre[maxn],Path[maxn],Head[maxn],cnt, f[maxn];
double Dist[maxn];
bool vis[maxn]; void addedge(int u, int v, int vol, double cost){
Node[cnt].to = v;
Node[cnt].vol = vol;
Node[cnt].cost = cost;
Node[cnt].next = Head[u];
Head[u] = cnt++; Node[cnt].to = u;
Node[cnt].vol = ;
Node[cnt].cost = -cost;
Node[cnt].next = Head[v];
Head[v] = cnt++;
} bool Spfa(int s, int t){
for(int i = ;i < maxn;i++) Dist[i] = INF*1.0;
memset(Pre, -, sizeof(Pre));
memset(vis, false, sizeof(vis));
Dist[s] = 0.0;
queue<int>Q;
vis[s] = true;
Q.push(s);
f[s] = INF;
while (!Q.empty()){
int u = Q.front();
Q.pop();
vis[u] = false;
for (int e = Head[u]; e != -; e = Node[e].next){
int v = Node[e].to;
if (Node[e].vol > && Dist[v] - Dist[u] - Node[e].cost > eps){
Dist[v] = Dist[u] + Node[e].cost;
Pre[v] = u;
Path[v] = e;
f[Node[e].to] = min(f[u], Node[e].vol);
if(!vis[v]){
vis[v] = true;
Q.push(v);
}
}
}
}
if(Pre[t] == -) return ;
int u, v, e;
for(u = t; u != s; u = Pre[u]){
e = Path[u];
Node[e].vol -= f[t];
Node[e^].vol += f[t];
}
max_flow += f[t];
value += (double)f[t]*Dist[t];
return ;
} void MCMF(int s, int t)
{
max_flow = ;
value = ;
while(Spfa(s, t));
} void init(){
memset(Head,-,sizeof(Head));
cnt = ;
} int main(){
int t,n,m,a[maxn],b[maxn],c[maxn];
int u,v,cap;
double p;
scanf("%d",&t);
while(t--){
init();
scanf("%d%d",&n,&m);
for(int i = ;i <= n;i++){
scanf("%d%d",&a[i],&b[i]);
c[i] = a[i]-b[i];
}
while(m--){
scanf("%d%d%d%lf",&u,&v,&cap,&p);
p = -log2(1.0-p);
if(cap > ) addedge(u,v,,0.0);
if(cap- > ) addedge(u,v,cap-,p);
}
for(int i = ;i <= n;i++){
if(c[i] > ) addedge(,i,c[i],0.0);
else if(c[i] < ) addedge(i,n+,-c[i],0.0);
}
MCMF(,n+);
double ans = pow(,-value);
printf("%.2f\n",1.0-ans);
}
return ;
}
Coding Contest HDU - 5988(费用流)的更多相关文章
- HDU 5988 Coding Contest(浮点数费用流)
http://acm.split.hdu.edu.cn/showproblem.php?pid=5988 题意:在acm比赛的时候有多个桌子,桌子与桌子之间都有线路相连,每个桌子上会有一些人和一些食物 ...
- Going Home HDU - 1533 费用流
http://acm.hdu.edu.cn/showproblem.php?pid=1533 给一个网格图,每两个点之间的匹配花费为其曼哈顿距离,问给每个的"$m$"匹配到一个&q ...
- hdu 5045 费用流
滚动建图,最大费用流(每次仅仅有就10个点的二分图).复杂度,m/n*(n^2)(n<=10),今年网络赛唯一网络流题,被队友状压DP秒了....难道网络流要逐渐退出历史舞台???.... #i ...
- HDU 3376 费用流 Matrix Again
题意: 给出一个n × n的矩阵,每个格子中有一个数字代表权值,找出从左上角出发到右下角的两条不相交的路径(起点和终点除外),使得两条路径权值之和最大. 分析: 如果n比较小的话是可以DP的,但是现在 ...
- hdu 2686 费用流 / 双线程DP
题意:给一个方阵,求从左上角出到右下角(并返回到起点),经过每个点一次不重复,求最大获益(走到某处获得改点数值),下来时每次只能向右或向下,反之向上或向左. 俩种解法: 1 费用流法:思路转化:从左 ...
- hdu 4406 费用流
这题问题就是当前时刻究竟选择哪门课程,易知选择是和分数有关的,而且是一个变化的权值,所以能够用拆点的方式,把从基础分到100分都拆成点.但若这样拆点的话,跑费用流时就必须保证顺序.这样就麻烦了..观察 ...
- hdu 1853 (费用流 拆点)
// 给定一个有向图,必须用若干个环来覆盖整个图,要求这些覆盖的环的权值最小. 思路:原图每个点 u 拆为 u 和 u' ,从源点引容量为 1 费用为 0 的边到 u ,从 u' 引相同性质的边到汇点 ...
- HDU 3667 费用流 拆边 Transportation
题意: 有N个城市,M条有向道路,要从1号城市运送K个货物到N号城市. 每条有向道路<u, v>运送费用和运送量的平方成正比,系数为ai 而且每条路最多运送Ci个货物,求最小费用. 分析: ...
- HDU 3667 费用流(拆边)
题意:有n个城市(1~n),m条有向边:有k件货物要从1运到n,每条边最多能运c件货物,每条边有一个危险系数ai,经过这条路的费用需要ai*x2(x为货物的数量),问所有货物安全到达的费用. 思路:c ...
随机推荐
- python伪代码之爬取完美志愿全国历年文理分数线运行代码持续更新
最近好多小伙伴说想搞个项目实战类的,我就花了一点时间做了一个爬虫项目(在代码复制的时候可能会有点问题,缩格一下就没有问题了) 想要获取更多源码或者答疑或者或者交流学习可以加群:725479218 # ...
- 两个非常好的bootstrap模板,外送大话设计模式!
两个非常好的bootstrap模板,外送大话设计模式! 下载地址:http://download.csdn.net/download/wolongbb/10198756
- Jenkins 配置 Node.js 项目
开始 弄清楚 Jenkins 服务器 用 Jenkins 管理员账号下载 NodeJS Plugin 系统管理 ---> 全局工具配置 ---> NodeJS ---> 安装 --- ...
- ES7 之 Async/await 的使用
在 js 异步请求数据时,通常,我们多采用回调函数的方式解决,但是,如果有多个回调函数嵌套时,代码显得很不优雅,维护成本也相应较高. ES6 提供的 Promise 方法和 ES7 提供的 Async ...
- (7)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- 利用Polly+AOP+依赖注入封装的降级框架
创建简单的熔断降级框架 要达到的目标是: 参与降级的方法参数要一样,当HelloAsync执行出错的时候执行HelloFallBackAsync方法. public class Person { [H ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(63)-WebApi与Unity注入
系列目录 前言: 有时候我们系统需要开放数据给手机App端或其他移动设备,不得不说Asp.net WebApi是目前首选 本节记录Asp.net MVC WebApi怎么利用Unity注入.系列开头已 ...
- rem、em、px、pt及网站字体大小设配
rem:相对的只是HTML根元素字体尺寸; em:相对于当前对象内文本的字体尺寸(值不是固定且继承父级元素的字体大小); px像素(Pixel):对于显示器屏幕分辨率而言的; pt:point,是印刷 ...
- 个人博客作业-Week7
团队任务中个人感想 我们团队选的题目是爬虫, 采用用AVA平台开发了, 我原来JAVA语言不熟悉了, PM考虑这部分之后分配任务这部分感觉很多谢 团队当中的PM很清楚每个组员的力量, 所以PM跟每个组 ...
- Opentsdb分布式安装
Opentsdb分布式安装 --李琦 1.下载文件上传到虚拟机 -rw-r--r--. 1 root root 76793860 Apr 27 10:56 opentsdb-2.2.0.tar ...
- Github学习心得体会
https://github.com/Accredit/TEST 在本学期第一次接触Github,在系统的学习了Github的使用之后,自己对Github有了一个基本的使用了解.在这个过程中,自己也认 ...