FJWC2019 最短路
题目描述
有一张无向图,开始的时候所有边权为1,所有点没有权值,现在给定一个整数k,表示可以将k个点的点权设置为1,求点0到n-1的最短路最长是多少
Solution
网络流好题[然而本蒟蒻还是不会][这个建图是真的神仙…]
最短路最长,最大化最小的问题,考虑二分,我们先二分出一个mid,表示假设最短路最长是mid
然后建图建mid+1层,将每个点拆成两个点si和ti,从si向ti连一条流量为1的边,表示割掉这条边需要1的代价[割掉了就是+1s]
为了保证每个点只被选择一次,从这层的si向下一层的ti连一条流量为正无穷的边。然后对于本来图中存在的边<x,y>,从这层的tx向下一层的sy连一条流量为无穷的边
从这层的sn-1向下一层的sn-1连流量为无穷的边
如果从第一层的t0到mid+1层的sn-1的最小割<=k 向[mid+1,r]找,否则向[l,mid-1]找
[本蒟蒻理解这个建图理解了一个晚上x]

[效果大概长这样?][我画的图还是好丑啊]
然后建完图跑网络流就可以啦!
总效率O(能过)
Code
- #include <bits/stdc++.h>
- using namespace std;
- int T,K,N,M;
- const int fish1=101*101*4;
- const int fish2=8*101*101*101;
- vector<int> vec[fish1];
- int cnt,nex[fish2],las[fish2],Arrive[fish2],Flow[fish2];
- int d[fish1];
- void jt(int u,int v,int FF)
- {
- cnt++;
- nex[cnt]=las[u];
- las[u]=cnt;
- Arrive[cnt]=v;
- Flow[cnt]=FF;
- cnt++;
- nex[cnt]=las[v];
- las[v]=cnt;
- Arrive[cnt]=u;
- Flow[cnt]=0;
- }
- bool BFS()
- {
- memset(d,0,sizeof(d));
- d[2]=1;
- queue<int> qwq;
- qwq.push(2);
- while (!qwq.empty())
- {
- int R=qwq.front();
- qwq.pop();
- for (int i=las[R];i;i=nex[i])
- {
- if (Flow[i])
- {
- int RR=Arrive[i];
- if (!d[RR])
- {
- d[RR]=d[R]+1;
- qwq.push(RR);
- }
- }
- }
- }
- return d[T]>0;
- }
- int DFS(int Now,int flow)
- {
- if (!flow) return flow;
- if (Now==T) return flow;
- int ans=0;
- bool b=0;
- for (int i=las[Now];i;i=nex[i])
- {
- if (Flow[i])
- {
- int v=Arrive[i];
- if (d[v]!=d[Now]+1) continue;
- int tmp=DFS(v,min(Flow[i],flow));
- if (tmp)
- {
- flow-=tmp;
- ans+=tmp;
- Flow[i]-=tmp;
- Flow[i^1]+=tmp;
- b=1;
- if (!flow) break;
- }
- }
- }
- if(!b) d[Now]=-1;
- return ans;
- }
- int Dinic()
- {
- int ans=0;
- while (BFS())
- {
- ans+=DFS(2,1e6);
- if (ans>K) return ans;
- }
- return ans;
- }
- bool Check(int Now)
- {
- cnt=1;
- memset(las,0,sizeof(las));
- for (int i=1;i<=Now;i++)
- {
- for (int j=N-1;j>1;j--)
- jt((i-1)*2*N+j*2-1,(i-1)*2*N+j*2,1),jt((i-1)*2*N+j*2-1,i*2*N+j*2,1e6);
- for (int j=1;j<=N;j++)
- for (int k=vec[j].size()-1;k>=0;k--)
- jt((i-1)*2*N+j*2,i*2*N+(vec[j][k]*2)-1,1e6);
- jt((i-1)*2*N+N*2-1,i*2*N+(N*2)-1,1e6);
- }
- T=(Now+1)*2*N-1;
- return Dinic()<=K;
- }
- int main()
- {
- freopen("min.in","r",stdin);
- freopen("min.out","w",stdout);
- scanf("%d%d%d",&N,&M,&K);
- for (int i=1;i<=M;i++)
- {
- int u,v;
- scanf("%d%d",&u,&v);
- u++;
- v++;
- vec[u].push_back(v);
- vec[v].push_back(u);
- }
- int l=1,r=2*N,anss;
- while (l<=r)
- {
- int mid=(l+r)/2;
- if (Check(mid)) anss=mid,l=mid+1;
- else r=mid-1;
- }
- printf("%d",anss+1);
- return 0;
- }
FJWC2019 最短路的更多相关文章
- bzoj1001--最大流转最短路
http://www.lydsy.com/JudgeOnline/problem.php?id=1001 思路:这应该算是经典的最大流求最小割吧.不过题目中n,m<=1000,用最大流会TLE, ...
- 【USACO 3.2】Sweet Butter(最短路)
题意 一个联通图里给定若干个点,求他们到某点距离之和的最小值. 题解 枚举到的某点,然后优先队列优化的dijkstra求最短路,把给定的点到其的最短路加起来,更新最小值.复杂度是\(O(NElogE) ...
- Sicily 1031: Campus (最短路)
这是一道典型的最短路问题,直接用Dijkstra算法便可求解,主要是需要考虑输入的点是不是在已给出的地图中,具体看代码 #include<bits/stdc++.h> #define MA ...
- 最短路(Floyd)
关于最短的先记下了 Floyd算法: 1.比较精简准确的关于Floyd思想的表达:从任意节点A到任意节点B的最短路径不外乎2种可能,1是直接从A到B,2是从A经过若干个节点X到B.所以,我们假设maz ...
- bzoj1266最短路+最小割
本来写了spfa wa了 看到网上有人写Floyd过了 表示不开心 ̄へ ̄ 改成Floyd试试... 还是wa ヾ(。`Д´。)原来是建图错了(样例怎么过的) 结果T了 于是把Floyd改回spfa 还 ...
- HDU2433 BFS最短路
Travel Time Limit: 10000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...
- 最短路(代码来源于kuangbin和百度)
最短路 最短路有多种算法,常见的有一下几种:Dijstra.Floyd.Bellman-Ford,其中Dijstra和Bellman-Ford还有优化:Dijstra可以用优先队列(或者堆)优化,Be ...
- Javascript优化细节:短路表达式
什么是短路表达式? 短路表达式:作为"&&"和"||"操作符的操作数表达式,这些表达式在进行求值时,只要最终的结果已经可以确定是真或假,求值过程 ...
- Python中三目计算符的正确用法及短路逻辑
今天在看别人代码时看到这样一种写法, 感觉是个挺容易踩到的坑, 搞清楚后写出来备忘. 短路逻辑 Python中进行逻辑运算的时候, 默认采用的是一种叫做短路逻辑的运算规则. 名字是很形象的, 下面直接 ...
随机推荐
- [Training Video - 1] [Selenium Basics] [Install Selenium IDE]
Download and Install Selenium IDE
- malloc.c
glibc-2.14中的malloc.c源代码,供研究malloc和free实现使用: /* Malloc implementation for multiple threads without lo ...
- UILabel 字体下方加下划线
UILabel *knowKankan = [[UILabel alloc] initWithFrame:CGRectMake(0, MAINHEIGHT - 78 , MAINWIDTH, ...
- Modelsim10.2c使用教程(一个完整工程的仿真)
之前玩过Altera的板子,不不, 现在应该叫intel PSG.在QuartusII13.0上老喜欢用modelsim_ae做仿真,小工程用起来也方便,但是我做IIC配置摄像头的时序仿真时,就显得有 ...
- 数据恢复软Extundelete
1>概述 作为一名运维人员,保证数据的安全是根本职责,所以在维护系统的时候,要慎重和细心,但是有时也难免发生出现数据被误删除的情况,这个时候该如何 快速.有效地恢复数 ...
- .net core webapi 定义多版本与 Swagger 的文档输出
前提: 需要nuget 以下两个程序集 Swashbuckle.AspNetCore 我暂时用的是 4.01: Microsoft.AspNetCore.Mvc.Versioning.ApiExp ...
- ADO.NET操作SQL Server:数据库操作类(已封装)
1.增.删.改通用方法 /// <summary> /// 增.删.改通用方法 /// </summary> /// <param name="commandT ...
- C++多线程 生产者 消费者示例
之前写过一篇关于多线程的https://blog.csdn.net/qq_21049875/article/details/79589126. 为了复习一下C++多线程的使用,以及程序的编写,于是 ...
- django系列4.2--自定义标签, 自定义过滤器, inclusion_tag, 引入静态文件(css,js等)
项目的目录为 在app中创建templates时,最好要再创建一个app名相同的文件夹,因为项目找文件时从第一个app开始遍历,不同app内的同名文件会有冲突,所以这样处理 一.自定义标签和过滤器 1 ...
- ADB 源码分析(一) ——ADB模块简述【转】
ADB源码分析(一)——ADB模块简述 1.Adb 源码路径(system/core/adb). 2.要想很快的了解一个模块的基本情况,最直接的就是查看该模块的Android.mk文件,下面就来看看a ...