题意:

  有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(费用流)的更多相关文章

  1. HDU 5988 Coding Contest(浮点数费用流)

    http://acm.split.hdu.edu.cn/showproblem.php?pid=5988 题意:在acm比赛的时候有多个桌子,桌子与桌子之间都有线路相连,每个桌子上会有一些人和一些食物 ...

  2. Going Home HDU - 1533 费用流

    http://acm.hdu.edu.cn/showproblem.php?pid=1533 给一个网格图,每两个点之间的匹配花费为其曼哈顿距离,问给每个的"$m$"匹配到一个&q ...

  3. hdu 5045 费用流

    滚动建图,最大费用流(每次仅仅有就10个点的二分图).复杂度,m/n*(n^2)(n<=10),今年网络赛唯一网络流题,被队友状压DP秒了....难道网络流要逐渐退出历史舞台???.... #i ...

  4. HDU 3376 费用流 Matrix Again

    题意: 给出一个n × n的矩阵,每个格子中有一个数字代表权值,找出从左上角出发到右下角的两条不相交的路径(起点和终点除外),使得两条路径权值之和最大. 分析: 如果n比较小的话是可以DP的,但是现在 ...

  5. hdu 2686 费用流 / 双线程DP

    题意:给一个方阵,求从左上角出到右下角(并返回到起点),经过每个点一次不重复,求最大获益(走到某处获得改点数值),下来时每次只能向右或向下,反之向上或向左. 俩种解法: 1  费用流法:思路转化:从左 ...

  6. hdu 4406 费用流

    这题问题就是当前时刻究竟选择哪门课程,易知选择是和分数有关的,而且是一个变化的权值,所以能够用拆点的方式,把从基础分到100分都拆成点.但若这样拆点的话,跑费用流时就必须保证顺序.这样就麻烦了..观察 ...

  7. hdu 1853 (费用流 拆点)

    // 给定一个有向图,必须用若干个环来覆盖整个图,要求这些覆盖的环的权值最小. 思路:原图每个点 u 拆为 u 和 u' ,从源点引容量为 1 费用为 0 的边到 u ,从 u' 引相同性质的边到汇点 ...

  8. HDU 3667 费用流 拆边 Transportation

    题意: 有N个城市,M条有向道路,要从1号城市运送K个货物到N号城市. 每条有向道路<u, v>运送费用和运送量的平方成正比,系数为ai 而且每条路最多运送Ci个货物,求最小费用. 分析: ...

  9. HDU 3667 费用流(拆边)

    题意:有n个城市(1~n),m条有向边:有k件货物要从1运到n,每条边最多能运c件货物,每条边有一个危险系数ai,经过这条路的费用需要ai*x2(x为货物的数量),问所有货物安全到达的费用. 思路:c ...

随机推荐

  1. SQL Server CTE 递归查询全解(转载)

    在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,本文详细介绍CTE递归调用的特性和使用示例 ...

  2. c# 设置桌面背景窗口 SetParent

    using System; using System.Drawing; using System.Runtime.InteropServices; using System.Windows.Forms ...

  3. RabbmitMQ-组成及简单使用

    什么是MQ? MQ全程Message Queue,消息队列(MQ)是一种应用程序对应用程序的通信方法.MQ是消费者-生产者模型的典型代表.一端往消息队列中不断写消息而另一端则可以读取队列中的消息. R ...

  4. ETL流程介绍及常用实现方法

    ETL是英文Extract-Transform-Load 的缩写,用来描述将数据从来源端经过抽取(extract).转换(transform).加载(load)至目的端的过程.常见于数据仓库开发中将数 ...

  5. 记一次在.NET成长之路上的下午茶

    在2017年2月25日我和李海国有幸与阳铭.朱永光两位大哥喝了一次下午茶.熟悉ABP框架的朋友呢知道阳铭远在上海,所以个人很是珍惜这次机会.朱永光大哥是微软MVP,之前是启路科技的CTO,目前在微软. ...

  6. C#_根据银行卡卡号判断银行名称

    /// <summary> /// 银行信息 /// </summary> public class BankInfo { #region 数组形式存储银行BIN号 /// & ...

  7. Matlab入门笔记(1)

    1.简单练习题: cos(((1+2+3+4+5)^3/5)^0.5) sin(pi^0.5)+log(tan(1)) 2^(3.5*1.7) exp(sin(10)) 2.实数,复数,行向量,列向量 ...

  8. 实践简单的项目WC

    #include<iostream> #include<fstream> #include<string> #include<Windows.h> us ...

  9. alpa开发阶段团队贡献分

    这是我们团队之前决定的分配方式: 1.凡是认真完成自己任务的队员,都将有基础分30分(态度分). 2. 将整个项目细化为不同的任务,列出一个任务清单,在综合.协调完每名成员的意愿后,我会分配清单中的任 ...

  10. ubuntu——caffe配置deeplab

    1. 下载deeplab 2. 安装matio sudo apt-get install libmatio-dev 3. 修改Makefile文件 LIBRARIES += glog gflags p ...