题目描述

有一张无向图,开始的时候所有边权为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

  1. #include <bits/stdc++.h>  
  2. using namespace std;  
  3. int T,K,N,M;  
  4. const int fish1=101*101*4;  
  5. const int fish2=8*101*101*101;  
  6. vector<int> vec[fish1];  
  7. int cnt,nex[fish2],las[fish2],Arrive[fish2],Flow[fish2];  
  8. int d[fish1];  
  9. void jt(int u,int v,int FF)  
  10. {  
  11.     cnt++;  
  12.     nex[cnt]=las[u];  
  13.     las[u]=cnt;  
  14.     Arrive[cnt]=v;  
  15.     Flow[cnt]=FF;  
  16.     cnt++;  
  17.     nex[cnt]=las[v];  
  18.     las[v]=cnt;  
  19.     Arrive[cnt]=u;  
  20.     Flow[cnt]=0;  
  21. }  
  22. bool BFS()  
  23. {  
  24.     memset(d,0,sizeof(d));  
  25.     d[2]=1;  
  26.     queue<int> qwq;  
  27.     qwq.push(2);  
  28.     while (!qwq.empty())  
  29.     {  
  30.         int R=qwq.front();  
  31.         qwq.pop();  
  32.         for (int i=las[R];i;i=nex[i])  
  33.           {  
  34.             if (Flow[i])  
  35.              {  
  36.                 int RR=Arrive[i];  
  37.                 if (!d[RR])  
  38.                    {  
  39.                    d[RR]=d[R]+1;  
  40.                    qwq.push(RR);  
  41.                   }  
  42.              }  
  43.           }  
  44.     }  
  45.     return d[T]>0;  
  46. }  
  47. int DFS(int Now,int flow)  
  48. {  
  49.     if (!flow) return flow;  
  50.     if (Now==T) return flow;  
  51.     int ans=0;  
  52.     bool b=0;  
  53.     for (int i=las[Now];i;i=nex[i])  
  54.       {  
  55.         if (Flow[i])  
  56.           {  
  57.             int v=Arrive[i];  
  58.             if (d[v]!=d[Now]+1) continue;  
  59.             int tmp=DFS(v,min(Flow[i],flow));  
  60.             if (tmp)  
  61.             {  
  62.                 flow-=tmp;  
  63.                 ans+=tmp;  
  64.                 Flow[i]-=tmp;  
  65.                 Flow[i^1]+=tmp;  
  66.                 b=1;  
  67.                 if (!flow) break;  
  68.             }  
  69.           }  
  70.       }  
  71.       if(!b) d[Now]=-1;  
  72.     return ans;  
  73. }  
  74. int Dinic()  
  75. {  
  76.     int ans=0;  
  77.     while (BFS())  
  78.     {  
  79.         ans+=DFS(2,1e6);  
  80.         if (ans>K) return ans;  
  81.     }  
  82.     return ans;  
  83. }  
  84. bool Check(int Now)  
  85. {  
  86.     cnt=1;  
  87.     memset(las,0,sizeof(las));  
  88.     for (int i=1;i<=Now;i++)  
  89.       {  
  90.         for (int j=N-1;j>1;j--)  
  91.           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);  
  92.           for (int j=1;j<=N;j++)  
  93.             for (int k=vec[j].size()-1;k>=0;k--)  
  94.                 jt((i-1)*2*N+j*2,i*2*N+(vec[j][k]*2)-1,1e6);  
  95.             jt((i-1)*2*N+N*2-1,i*2*N+(N*2)-1,1e6);  
  96.       }  
  97.     T=(Now+1)*2*N-1;  
  98.     return Dinic()<=K;  
  99. }  
  100. int main()  
  101. {  
  102.     freopen("min.in","r",stdin);  
  103.     freopen("min.out","w",stdout);  
  104.     scanf("%d%d%d",&N,&M,&K);  
  105.     for (int i=1;i<=M;i++)  
  106.       {  
  107.         int u,v;  
  108.         scanf("%d%d",&u,&v);  
  109.         u++;  
  110.         v++;  
  111.         vec[u].push_back(v);  
  112.         vec[v].push_back(u);  
  113.       }  
  114.       int l=1,r=2*N,anss;  
  115.       while (l<=r)  
  116.       {  
  117.         int mid=(l+r)/2;  
  118.         if (Check(mid)) anss=mid,l=mid+1;  
  119.         else r=mid-1;  
  120.       }  
  121.       printf("%d",anss+1);  
  122.     return 0;     
  123. }  

FJWC2019 最短路的更多相关文章

  1. bzoj1001--最大流转最短路

    http://www.lydsy.com/JudgeOnline/problem.php?id=1001 思路:这应该算是经典的最大流求最小割吧.不过题目中n,m<=1000,用最大流会TLE, ...

  2. 【USACO 3.2】Sweet Butter(最短路)

    题意 一个联通图里给定若干个点,求他们到某点距离之和的最小值. 题解 枚举到的某点,然后优先队列优化的dijkstra求最短路,把给定的点到其的最短路加起来,更新最小值.复杂度是\(O(NElogE) ...

  3. Sicily 1031: Campus (最短路)

    这是一道典型的最短路问题,直接用Dijkstra算法便可求解,主要是需要考虑输入的点是不是在已给出的地图中,具体看代码 #include<bits/stdc++.h> #define MA ...

  4. 最短路(Floyd)

    关于最短的先记下了 Floyd算法: 1.比较精简准确的关于Floyd思想的表达:从任意节点A到任意节点B的最短路径不外乎2种可能,1是直接从A到B,2是从A经过若干个节点X到B.所以,我们假设maz ...

  5. bzoj1266最短路+最小割

    本来写了spfa wa了 看到网上有人写Floyd过了 表示不开心 ̄へ ̄ 改成Floyd试试... 还是wa ヾ(。`Д´。)原来是建图错了(样例怎么过的) 结果T了 于是把Floyd改回spfa 还 ...

  6. HDU2433 BFS最短路

    Travel Time Limit: 10000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  7. 最短路(代码来源于kuangbin和百度)

    最短路 最短路有多种算法,常见的有一下几种:Dijstra.Floyd.Bellman-Ford,其中Dijstra和Bellman-Ford还有优化:Dijstra可以用优先队列(或者堆)优化,Be ...

  8. Javascript优化细节:短路表达式

    什么是短路表达式? 短路表达式:作为"&&"和"||"操作符的操作数表达式,这些表达式在进行求值时,只要最终的结果已经可以确定是真或假,求值过程 ...

  9. Python中三目计算符的正确用法及短路逻辑

    今天在看别人代码时看到这样一种写法, 感觉是个挺容易踩到的坑, 搞清楚后写出来备忘. 短路逻辑 Python中进行逻辑运算的时候, 默认采用的是一种叫做短路逻辑的运算规则. 名字是很形象的, 下面直接 ...

随机推荐

  1. file_get_contents()

    file_get_contents()类似于curl接口调用

  2. 06 Python字符编码与文件处理

    python垃圾回收机制: python中的垃圾回收机制是以引用计数为主,分代收集为辅,引用计数的缺陷是循环引用的问题,一个对象的引用数为0 ,那么这个对象就会被python虚拟机回收内存 字符编码 ...

  3. java 内存 线程 类 vm分析工具

    JMeter.Jconsole.JVMStat

  4. 3D 相关

    1. STL 2. AMF 3. X3D 网址: http://www.web3d.org/x3d-resources/content/examples/X3dResources.html

  5. CentOS 6.0下phpvod搭建教程(LAMP+phpvod)

    之所以安装CentOS是因为之前试过RedHat,但是发现RedHat在安装时,无法获取安装源,原因是RedHat系统没有在RHN注册. 网上的很多教程都说可以直接换用CentOS的源,可我小搞里一会 ...

  6. FNDLOAD Commands to Download Different Seed Data Types. (DOC ID 274667.1)

    In this Document Goal Solution References Applies to: Oracle Application Object Library - Version 11 ...

  7. ASP.NET Core2实现静默获取微信公众号的用户OpenId

    最近在做个微信公众号的项目,需要将入口放置在公众号二级菜单内,通过点击该菜单链接后进入到该项目中去,进入到项目后程序会自动通过微信公众号的API完成用户的OpenId获取.需求很简单,实现起来也不复杂 ...

  8. [Erlang29]进程收到不是期望的消息时怎么办?

    最近在项目中升级了第三方库,导致本应用gen_server中A进程中: handle_info({add,X},Sum) -> {noreply,Sum+X}; 结果这么简单的一个工作居然不工作 ...

  9. [Erlang20]一起攻克Binary

    第一次看到Joe Armstong的<Erlang 程序设计>里面对Binary的描述时,觉得这个东西好复杂,语法这么奇特(我觉得是Erlang语法中最不好懂的部分); 然后在项目中:Bi ...

  10. Centos7 创建Eclipse启动

    Eclipse是一个集成开发环境(IDE),包含一个基工作区和定制环境的可扩展插件系统.大部分使用 Java 编写,Eclipse 可以用来开发应用程序.通过各种插件,Eclipse 也可以用于其他编 ...