题解-CF1307G Cow and Exercise
给 \(n\) 点 \(m\) 边的带权有向图,边 \(i\) 为 \((u_i,v_i,w_i)\)。\(q\) 次询问,每次给 \(x_i\),问修改一些边使整张图的边权和增加 \(x_i\) 后最短路最大值(可以把边权修改为浮点数)。
数据范围:\(2\le n\le 50\),\(1\le m\le n\cdot (n-1)\),\(1\le u_i,v_i\le n\),\(1\le w_i\le 10^6\),\(1\le q\le 10^5\),\(0\le x_i\le 10^5\)。
学网络流不能错过的经典例题啊!这题的思想真是又巧妙又易懂又实用。
我写的题解如下,貌似废话很多。。。
如下图:
如果 \(x=0\),最短路最长为 \(7\)。
如果 \(x=1\),最短路最长为 \(8\)。\((1,4,3)\to(1,4,4)\)。
如果 \(x=2\),最短路最长为 \(9\)。\((1,4,3)\to(1,4,5)\)。
如果 \(x=3\),最短路最长为 \(9.5\)。\((1,4,3)\to(1,4,5.5)\),\((1,2,4)\to(1,2,4.5)\)。
如果 \(x=4\),最短路最长为 \(10\)。\((1,4,3)\to(1,4,6)\),\((1,2,4)\to(1,2,5)\)。
\(\cdots\)
直到 \(x=\infty\),都只需要改 \((1,4,3)\) 和 \((1,2,4)\) 两条边。
因为它们是图中三条路径的必经之路。
学过的人应该可以发现:它们便是无权图上的最小割边。
要使带权图最短路最长,修改最小割边是最优的。
将经过同一个最小割边的路径归为一个路径集。
如上图中,设经过 \((1,2,4)\) 的路径集为 \(S_1\),经过 \((1,4,3)\) 的路径集为 \(S_2\)。
当 \(0\le x\le 2\) 时,只需修改 \(S_2\) 的割边 \((1,4,3)\)。
当 \(3\le x\) 时,需要修改 \(S_1\) 和 \(S_2\) 的割边,并要使两个路径集的最短路径相等。
类推一下,根据平均的思想,可以得出:
无论 \(x\) 取何值,修改最短路径长度最短的 \(k\) 个路径集,并使它们修改后相等是最优的。
假设这 \(k\) 个路径集修改后的最短路径都为 \(L\),则应有对于任何未被修改割边的路径集,最短路径长度 \(\ge L\)。否则去修改这条路径必然更优。
所以就可以让费用流算法上路了,这题建议用 \(\tt EK\),因为这东西很乖的,一次就增广一个路径集。
回想一下 \(\tt EK\) 的套路:\(\tt Spfa\) 找到最短路,然后增广。
如果让网络流的边 \(flow_i=1,cost_i=w_i\),则有:
增广 \(k\) 次后,当前的 \(flow=k\),并且当前的 \(cost\) 为 \(k\) 个路径集的最短路长度和。
所以可以把每次增广后的 \(flow\) 和 \(cost\) 扔进 \(\tt vector\) 里。
然后对于每个询问,\(Res=\min\{\frac{cost_j+x}{flow_j}\}\)。
这时有个问题:要是 \(j\) 不等于最优的 \(k\) 怎么办?
有个很神奇的结论:对于 \(j=k\) 的情况,\(\frac{cost_j+x}{flow_j}\) 最小。
根据上面的结论,如果 \(j>k\),因为把最短路径更长的路径集也考虑进来了,所以 \(\frac{cost_j+x}{flow_j}>\frac{cost_k+x}{flow_k}\)。
如果 \(j<k\),那么修改完后这 \(j\) 个路径集的最短路径会 \(>\) 剩下未被修改的 \(k-j\) 个路径集,所以也可得这结论。
时间复杂度 \(\Theta(n^4+nq)\)。
- 代码
#include <bits/stdc++.h>
using namespace std;
//Start
typedef long long ll;
typedef double db;
#define mp(a,b) make_pair(a,b)
#define x first
#define y second
#define b(a) a.begin()
#define e(a) a.end()
#define sz(a) int((a).size())
#define pb(a) push_back(a)
const int inf=0x3f3f3f3f;
const ll INF=0x3f3f3f3f3f3f3f3f;
//Data
const int N=50;
int n,m,q;
vector<pair<int,int>> fc;
//EK
int fn,s,t;
vector<int> e[N+7],to,fw,co;
void add(int u,int v,int f,int c){
e[u].pb(sz(to)),to.pb(v),fw.pb(f),co.pb(+c);
e[v].pb(sz(to)),to.pb(u),fw.pb(0),co.pb(-c);
}
int dep[N+7],p[N+7],vis[N+7];
int Bfs(){
for(int i=1;i<=fn;i++) dep[i]=inf,vis[i]=0;
queue<int> q; q.push(s),vis[s]=1,dep[s]=0;
while(sz(q)){
int u=q.front(); q.pop(),vis[u]=0;
for(int&v:e[u])if(fw[v]&&dep[to[v]]>dep[u]+co[v]){
dep[to[v]]=dep[u]+co[v],p[to[v]]=v;
if(!vis[to[v]]) vis[to[v]]=1,q.push(to[v]);
}
}
return dep[t]<inf;
}
int flow,cost;
void EK(){
while(Bfs()){
int f=inf;
for(int i=t;i!=s;i=to[p[i]^1]) f=min(f,fw[p[i]]);
flow+=f,cost+=dep[t]*f;
for(int i=t;i!=s;i=to[p[i]^1]) fw[p[i]]-=f,fw[p[i]^1]+=f;
fc.pb(mp(flow,cost));
}
}
//Main
int main(){
scanf("%d%d",&n,&m);
for(int i=1,u,v,w;i<=m;i++)
scanf("%d%d%d",&u,&v,&w),add(u,v,1,w);
s=1,t=fn=n,EK();
scanf("%d",&q);
for(int i=1,x;i<=q;i++){
scanf("%d",&x);
db res=inf;
for(auto d:fc) res=min(res,db(d.y+x)/d.x);
printf("%.10lf\n",res);
}
return 0;
}
祝大家学习愉快!
题解-CF1307G Cow and Exercise的更多相关文章
- 【题解】Cow Relays
题目大意 求在一张有\(m\)条边无向连通图中,点\(s\)到点\(t\)的经过\(k\)条边的最短路(\(1 \leq m \leq 100\),\(1 \leq k \leq 10^6\)). ...
- 【codeforces - 1307G】Cow and Exercise
目录 description solution accepted code details description 给定 n 点 m 边简单有向图,有边权. q 次询问,每次给出 xi.可以增加某些边 ...
- 树&图 记录
A - Lake Counting POJ - 2386 最最最最最基础的dfs 挂这道题为了提高AC率(糖水不等式 B - Paint it really, really dark gray Cod ...
- 「题解」:毛一琛/$cow$ $subsets$
问题 A: 毛一琛/$cow$ $subsets$ 时间限制: 1 Sec 内存限制: 512 MB 题面 题面谢绝公开. 题解 题名貌似是个大神??看起来像是签到题然后就死了. 首先$O(3^n) ...
- 题解【洛谷P2853】[USACO06DEC]牛的野餐Cow Picnic
题目描述 The cows are having a picnic! Each of Farmer John's \(K (1 ≤ K ≤ 100)\) cows is grazing in one ...
- POJ 3263 Tallest Cow 题解
题目 FJ's \(N (1 ≤ N ≤ 10,000)\) cows conveniently indexed 1..N are standing in a line. Each cow has a ...
- USACO07NOV Cow Relays G 题解
题目 For their physical fitness program, \(N (2 ≤ N ≤ 1,000,000)\) cows have decided to run a relay ra ...
- Hdoj 2717.Catch That Cow 题解
Problem Description Farmer John has been informed of the location of a fugitive cow and wants to cat ...
- BZOJ1604 & 洛谷2906:[USACO2008 OPEN]Cow Neighborhoods 奶牛的邻居——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=1604 https://www.luogu.org/problemnew/show/P2906#sub ...
随机推荐
- HotSpot的启动过程(配视频进行源码分析)
本文将详细介绍HotSpot的启动过程,启动过程涉及到的逻辑比较复杂,细节也比较多,为了让大家更快的了解这部分知识,我录制了对应的视频放到了B站上,大家可以参考. 第4节-HotSpot的启动过程 下 ...
- 论文学习笔记 - 高光谱 和 LiDAR 融合分类合集
A³CLNN: Spatial, Spectral and Multiscale Attention ConvLSTM Neural Network for Multisource Remote Se ...
- 丢了ceph.mon.keying解决办法
在linux操作系统下,可能因为一些很小的误操作,都会造成非常重要的文件的丢失,而文件的备份并不是每时每刻都会注意到,一般是等到文件丢失了才会去想办法,这里讲下ceph.mon.keyring丢失的解 ...
- Python网络编程_抓取百度首页代码(注释详细)
1 #coding=utf-8 2 #网络编程 3 4 #客户端建立socket套接字 5 #引入socket模块 6 import socket 7 #实例化一个套接字,2个参数分别是: IPV4. ...
- ERP出入库进阶操作与子流程--开源软件诞生28
赤龙ERP出入库进阶讲解--第28篇 用日志记录"开源软件"的诞生 [进入地址 点亮星星]----祈盼着一个鼓励 博主开源地址: 码云:https://gitee.com/redr ...
- FairyGUI编辑器的和unity里的Obj对应关系
1.在FairyGUI官网上下载好unity的工程,用FairyGUI编辑器打开它的官方案例 2.在FairyGUI编辑器和Unity中,从一个最简单的示例"Bag"着手. ...
- Java基础—Java方法的调用
Java方法的调用个主要有以下几种: 1.调用非静态方法 2.调用静态方法 3.方法与方法之间的调用 (1).静态方法内部调用其他方法 (2).非静态方法内部调用 1.调用非静态方法: 非静态方法的调 ...
- 应用程序-特定 权限设置并未向在应用程序容器不可用 SID (不可用)中运行的地址 LocalHost (使用 LRPC) 中的用户...的 COM 服务器应用程序的 本地 激活 权限。此安全权限可以使用组件服务管理工具进行修改。
很久以前发现我们的业务服务器上出现一个System的系统严重错误,查找很久都没有找到解决办法,今日再次查看服务器发现报错更频繁,于是就搜集各种资料进行查找解决办法,终于找到了一个解决办法. 错误截图介 ...
- 如何使用会声会影制作动态logo字幕
日常生活中大家在参加一些婚礼.聚会的时候,LED屏幕上播放的视频里面常常会有一行字,它随着视频的播放自己也在不断地改变颜色,非常醒目.想必大家也想把这种动态文字用在自己的视频中,为视频增添亮点.那么今 ...
- FL Studio中如何制作和混音Dutch Lead(上)
Dutch Lead是电子音乐类型Dutch House以及Bigroom House中常用的Lead音色,这一篇文章中我将从制作和混音两方面来讲解Dutch Lead. (一).Dutch Lead ...