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 ...
随机推荐
- java 变量及数据类型、原码、反码、补码
Java基础——变量及数据类型 变量的概念 内存中的一个存储区域 变量名+数据类型 可在同一类型范围内不断变化 为什么定义变量: 用于不断的存放同一类型的常量,并可以重复使用 使用变量注意: 变量的作 ...
- 使用Windows API进行串口编程
使用Windows API进行串口编程 串口通信一般分为四大步:打开串口->配置串口->读写串口->关闭串口,还可以在串口上监听读写等事件.1.打开和关闭串口Windows中串口 ...
- 办公室的远程传文件 的命令三种方式linux
不同的Linux之间copy文件常用有3种方法: 第一种就是ftp,也就是其中一台Linux安装ftp Server,这样可以另外一台使用ftp的client程序来进行文件的copy. 第二种方法就是 ...
- Spring+SpringMVC+MyBatis整合(easyUI、AdminLte3)
实战篇(付费教程) 花了几天的时间,做了一个网站小 Demo,最终效果也与此网站类似.以下是这次实战项目的 Demo 演示. 登录页: 富文本编辑页: 图片上传: 退出登录: SSM 搭建精美实用的管 ...
- Tomcat通过自带的Cluster方式实现Session会话共享环境操作记录
一般来说,在多个tomcat集群业务中,session会话共享是必须的需求,不然前端nginx转发过来的请求不知道之前请求在哪台tomcat节点上,从而就找不到session以至于最终导致请求失败.要 ...
- PAT甲级题解-1123. Is It a Complete AVL Tree (30)-AVL树+满二叉树
博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6806292.html特别不喜欢那些随便转载别人的原创文章又不给 ...
- Linux内核设计期中总结
Linux内核设计期中总结 ● 知识点 一.计算机是如何工作的 计算机是按照冯·诺依曼存储程序的原理. 在执行程序时须先将要执行的相关程序和数据放入内存储器中,在执行程序时CPU根据当前程序指针寄存器 ...
- 防止重复提交demo
利用session防止重复提交 思路: 前端控制:在点击提交按钮后设置按钮不可用. 后台控制:利用session,在初次进入表单页面的时候前生成一个随机token,将token保存到session并返 ...
- 关于本科毕业论文《Laguerre小波在数值积分与微分方程数值解中的应用》存在的问题与小结
本科的毕业设计<Laguerre小波在数值积分与微分方程数值解中的应用>是通过Laguerre小波函数来近似表达某个需要求积分或解微分方程的函数,将原函数很难求得函数用小波函数表达出来,这 ...
- 异常 try – finally 注意的地方
finally 异常机制中还有一个重要的部分,就是finally, catch后面可以跟finally语句,语法如下所示: try{ //可能抛出异常 }catch(Exception e){ / ...