链接:给一张n个点m条带权边的有向图,有x个人从起点出发到终点,每个人带的都带相同重量的货物, 
规定一条边最多能经过其上权的重量的货物,问最多能带多重的货物? 
2 ≤ n ≤ 50, 1 ≤ m ≤ 500, 1 ≤ x ≤ 100 000

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <algorithm>
#include <set>
using namespace std;
typedef long long ll;
typedef unsigned long long Ull;
#define MM(a,b) memset(a,b,sizeof(a));
const double eps = 1e-10;
const ll inf = 1e16;
const double pi=acos(-1);
const int mod=100000000; struct edge{
int to;
ll c;
int rev;
};//注意顺序关系与(edge){}对应 vector<edge> G[55];
vector<edge> F[55];
int level[55],iter[55];
int n,m,x,u,v,c; void bfs(int s)
{
queue<int> q;
q.push(s);
level[s]=1;
while(q.size())
{
int u=q.front();q.pop();
for(int i=0;i<G[u].size();i++)
{
edge e=G[u][i];
if(e.c>0&&level[e.to]==-1)
{
level[e.to]=level[u]+1;
q.push(e.to);
}
}
}
} double dfs(int s,int t,double minn)
{
if(s==t) return minn;
for(int &i=iter[s];i<G[s].size();i++)
{
edge &e=G[s][i];
if(e.c>0&&level[e.to]>level[s])
{
int d=dfs(e.to,t,min((double)minn,(double)e.c));
if(d>0)
{
e.c-=d;
G[e.to][e.rev].c+=d;
return d;
}
}
}
return 0;
} bool ok(double mid)
{
for(int i=1;i<=n;i++) G[i].clear();
for(int i=1;i<=n;i++)
for(int j=0;j<F[i].size();j++)
{
G[i].push_back(F[i][j]);
G[i][j].c=(ll)(F[i][j].c/mid);//精度很重要
}
double ans=0,temp;
for(;;)
{
MM(level,-1);
bfs(1);
if(level[n]<0) break;
MM(iter,0);
while((temp=dfs(1,n,inf))>0)
ans+=temp;
}
return ans>=x;
} int main()
{
double l,r;
while(~scanf("%d %d %d",&n,&m,&x))
{
for(int i=1;i<=n;i++) F[i].clear();
l=0;r=0;
for(int i=1;i<=m;i++)
{
scanf("%d %d %d",&u,&v,&c);
F[u].push_back((edge){v,c,F[v].size()});
F[v].push_back((edge){u,0,F[u].size()-1});
r=max(r,(double)c);//库里的max参数
}
for(int i=1;i<=200;i++)
{
double mid=(l+r)/2;
if(ok(mid)) l=mid;
else r=mid;
}
printf("%.10f\n",r*x);
}
return 0;
}

 分析:这道题精度卡的很恶心,但是用double的话这道题就没什么问题了;

参考资料 深刻的领会了long long的强大,,double的有效位数是15-17位,但是能表示的范围

可以达到10^308,,因为是科学计数法,,,double是 1.1234567890123456E指数这种表示的

TTTTTTTTTTTT CF 653D 送邮递员的更多相关文章

  1. 洛谷P1629 邮递员送信

    题目描述 有一个邮递员要送东西,邮局在节点1.他总共要送N-1样东西,其目的地分别是2~N.由于这个城市的交通比较繁忙,因此所有的道路都是单行的,共有M条道路,通过每条道路需要一定的时间.这个邮递员每 ...

  2. 从苹果apns的feedback服务器获取推送失败的token

    在开发自己的苹果推送服务时候,要合理的控制ios设备的Token,而这个Token是由苹果服务器Apns产生的,就是每次app问Apns要Token,由苹果服务器产生的Token会记录到Apns里面, ...

  3. codevs3872 邮递员送信(SPFA)

    邮递员送信 时间限制: 1 Sec  内存限制: 64 MB提交: 10  解决: 5[提交][状态][讨论版] 题目描述 有一个邮递员要送东西,邮局在节点1.他总共要送N-1样东西,其目的地分别是2 ...

  4. 百度云推送的Java实现

    推送现在基本APP都有,项目中要通知和消息,所以综合考虑用了百度云推送 Java实现步骤: 1. 下载 http://push.baidu.com/sdk/push_server_sdk_for_ja ...

  5. 利用pyapns进行ios推送

    ios客户端的同事提供了2个证书,分别是aps_development.cer  和 pushdevelopment.p12, 我最终目的就是把这2个证书合并成1个pem证书,然后通过pyapns进行 ...

  6. python 3.5构建WINDOWS推送服务

    import ConfigParser import os import sys cf = ConfigParser.ConfigParser() #绝对路径获取 ABSPATH=os.path.ab ...

  7. P1629 邮递员送信

    题目描述: 有一个邮递员要送东西,邮局在节点1.他总共要送N-1样东西,其目的地分别是2~N.由于这个城市的交通比较繁忙,因此所有的道路都是单行的,共有M条道路,通过每条道路需要一定的时间.这个邮递员 ...

  8. APNS IOS 消息推送处理失效的Token

    在开发苹果推送服务时候,要合理的控制ios设备的Token,而这个Token是由苹果服务器Apns产生的,就是每次app问Apns要Token,由苹果服务器产生的Token会记录到Apns里面,我们需 ...

  9. [题解]邮递员寄信(luoguP1629)

    题目来源:luoguP1629 题目描述 有一个邮递员要送东西,邮局在结点1.他总共要送N-1样东西,其目的地分别是2-N.由于这个城市的交通比较繁忙,因此所有的道路都是单行的,共有M条道路,通过每条 ...

随机推荐

  1. selenium Grid2环境搭建和基本使用

    Selenium Grid简介 利用Selenium Grid可以使主节点(hub)的测试用例在不同主机即分支点(node)运行.可以使一份测试用例在不同环境下(操作系统.浏览器)执行自动化测试.Se ...

  2. ps -ef

    status, msg = commands.getstatusoutput("ps -ef | grep start.sh | grep -Fv grep | awk '{print $1 ...

  3. 生成ini文件

    setProfileString是无法直接生成ini文件的,如果不存在这个ini文件需要先创建,然后再setProfileString.示例代码//保存连接参数到配置文件if not FileExis ...

  4. C# 面向对象3 静态和非静态的区别

    静态和非静态的区别 1.在非静态类中,既可以有实例成员(非静态成员),也可以有静态成员. 2.在调用实例成员的时候,需要使用对象名.实例成员; 在调用静态成员的时候,需要使用类名.静态成员名; 总结: ...

  5. node-images Windows 64-bit with Unsupported runtime 错误解决办法 及 node 历史版本下载

    在做项目的时候下载的最新的10.16[2019.6.12]版本,出现了模块不兼容的问题[node-images]. 在git上发现了相同问题 https://github.com/zhangyuanw ...

  6. abap 优化之ST05

    DATA: gt_mara TYPE TABLE OF mara. SELECT * INTO TABLE gt_mara FROM mara WHERE MATKL = 'L000001' %_hi ...

  7. 关于rpm包的安装卸载等

    在Linux操作系统中,有一个系统软件包,它的功能类似于Windows里面的“添加/删除程序”,但是功能又比“添加/删除程序”强很多,它就是Red Hat Package Manager(简称RPM) ...

  8. Spingboot使用log4j2

    1.pom.xml加入log4j2,并同时把spring boot默认的logging去掉,注意一定要全部排除否则会报错. <dependency> <groupId>org. ...

  9. Linux上安装postgres 10.5

    由于接触了华为的elk大数据平台,里面封装的是postgres ,就想着安装一下,熟悉一下postgres数据. 安装包下载:https://www.postgresql.org/ftp/source ...

  10. Q2Day79

    requests Python标准库中提供了:urllib.urllib2.httplib等模块以供Http请求,但是,它的 API 太渣了.它是为另一个时代.另一个互联网所创建的.它需要巨量的工作, ...