题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2229

题意:给定一个带权无向图。若干询问,每个询问回答有多少点对(s,t)满足s和t的最小割小于等于x。

思路:对于两个点(s,t)的最小割。这个最小割将将所有点分成左右两个集合X、Y。对于X中任意一点a与Y中任意一点b,(a,b)的最小割小于等于(s,t)的最小割。因此,每次递归计算分成的两个集合的最小割,更新答案。

  1. struct node
  2. {
  3. int v,cap,next;
  4. };
  5.  
  6. node edges[N*N*10];
  7. int head[N],e;
  8.  
  9. void add(int u,int v,int cap)
  10. {
  11. edges[e].v=v;
  12. edges[e].cap=cap;
  13. edges[e].next=head[u];
  14. head[u]=e++;
  15. }
  16.  
  17. void Add(int u,int v,int cap)
  18. {
  19. add(u,v,cap);
  20. add(v,u,0);
  21. }
  22.  
  23. int pre[N],cur[N],num[N],h[N];
  24.  
  25. int Maxflow(int s,int t,int n)
  26. {
  27. int i;
  28. for(i=0;i<=n;i++) cur[i]=head[i],num[i]=h[i]=0;
  29. int u=s,Min,k,v;
  30. int ans=0;
  31. while(h[u]<n)
  32. {
  33. if(u==t)
  34. {
  35. Min=INF;
  36. for(i=s;i!=t;i=edges[cur[i]].v)
  37. {
  38. k=cur[i];
  39. if(edges[k].cap<Min) Min=edges[k].cap,v=i;
  40. }
  41. ans+=Min; u=v;
  42. for(i=s;i!=t;i=edges[cur[i]].v)
  43. {
  44. k=cur[i];
  45. edges[k].cap-=Min;
  46. edges[k^1].cap+=Min;
  47. }
  48. }
  49. for(i=cur[u];i!=-1;i=edges[i].next)
  50. {
  51. if(edges[i].cap>0&&h[u]==h[edges[i].v]+1) break;
  52. }
  53. if(i!=-1)
  54. {
  55. cur[u]=i;
  56. pre[edges[i].v]=u;
  57. u=edges[i].v;
  58. }
  59. else
  60. {
  61. if(--num[h[u]]==0) break;
  62. k=n;
  63. cur[u]=head[u];
  64. for(i=head[u];i!=-1;i=edges[i].next)
  65. {
  66. if(edges[i].cap>0&&h[edges[i].v]<k)
  67. {
  68. k=h[edges[i].v];
  69. }
  70. }
  71. num[k+1]++;
  72. h[u]=k+1;
  73. if(u!=s) u=pre[u];
  74. }
  75. }
  76. return ans;
  77. }
  78.  
  79. int List[N][N],a[N][N],p[N][N];
  80. int n,m;
  81.  
  82. int MinCut[N][N];
  83. int b[N];
  84.  
  85. void build(int s,int t)
  86. {
  87. clr(head,-1); e=0;
  88. int i,j,u,v;
  89. FOR1(i,n)
  90. {
  91. u=i;
  92. for(j=1;j<=List[u][0];j++)
  93. {
  94. v=List[u][j];
  95. if(u!=t&&v!=s) Add(u,v,a[u][v]);
  96. }
  97. }
  98. }
  99.  
  100. int visit[N];
  101.  
  102. void DFS(int u)
  103. {
  104. visit[u]=1;
  105. int i,v;
  106. for(i=head[u];i!=-1;i=edges[i].next)
  107. {
  108. v=edges[i].v;
  109. if(edges[i].cap>0&&!visit[v]) DFS(v);
  110. }
  111. }
  112.  
  113. void DFS(int L,int R)
  114. {
  115. if(L==R) return;
  116. int s=b[L],t=b[R];
  117. build(s,t);
  118. int temp=Maxflow(s,t,n);
  119. clr(visit,0); DFS(s);
  120. int i,j,u,v,X[N],Y[N],xNum=0,yNum=0;
  121. for(i=L;i<=R;i++)
  122. {
  123. if(visit[b[i]]) X[++xNum]=b[i];
  124. else Y[++yNum]=b[i];
  125. }
  126. FOR1(i,n) if(visit[i]) FOR1(j,n) if(!visit[j])
  127. {
  128. u=i; v=j;
  129. MinCut[u][v]=MinCut[v][u]=min(MinCut[u][v],temp);
  130. }
  131. FOR1(i,xNum) b[L+i-1]=X[i];
  132. FOR1(j,yNum) b[L+xNum+j-1]=Y[j];
  133. DFS(L,L+xNum-1);
  134. DFS(L+xNum,R);
  135. }
  136.  
  137. int main()
  138. {
  139. rush()
  140. {
  141. RD(n,m);
  142. int i,j,u,v,w;
  143. FOR1(i,n) List[i][0]=0;
  144. clr(a,0); clr(p,0);
  145. FOR1(i,m)
  146. {
  147. RD(u,v,w);
  148. if(!p[u][v])
  149. {
  150. List[u][++List[u][0]]=v;
  151. List[v][++List[v][0]]=u;
  152. p[u][v]=p[v][u]=1;
  153. }
  154. a[u][v]+=w;
  155. a[v][u]+=w;
  156. }
  157. FOR1(i,n) b[i]=i;
  158. FOR1(i,n) FOR1(j,n) MinCut[i][j]=INF;
  159. DFS(1,n);
  160. int Q,x,ans;
  161. RD(Q);
  162. while(Q--)
  163. {
  164. RD(x); ans=0;
  165. FOR1(i,n) for(j=i+1;j<=n;j++) if(MinCut[i][j]<=x) ans++;
  166. PR(ans);
  167. }
  168. puts("");
  169. }
  170. }

BZOJ 2229 最小割的更多相关文章

  1. BZOJ 1412 & 最小割

    什么时候ZJ省选再现一次这么良心的题吧... 题意: 在一个染色的格子画分割线,使其不想连,求最少的线段 SOL: 裸裸的最小割.题目要求两种颜色不想连,我们把他分到两个集合,也就是把所有相连的边切断 ...

  2. BZOJ 1797 最小割

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1797 题意:给出一个有向图,每条边有流量,给出源点汇点s.t.对于每条边,询问:(1)是 ...

  3. bzoj 1497 最小割模型

    我们可以对于消费和盈利的点建立二分图,开始答案为所有的盈利和, 那么源向消费的点连边,流量为消费值,盈利向汇连边,流量为盈利值 中间盈利对应的消费连边,流量为INF,那么我们求这张图的最小割,用 开始 ...

  4. bzoj 1934 最小割

    收获: 1.流量为0的边可以不加入. 2.最小割方案要与决策方案对应. #include <cstdio> #include <cmath> #include <cstr ...

  5. bzoj 3996 最小割

    公式推出来后想了半天没思路,居然A是01矩阵..... 如果一个问题是求最值,并那么尝试先将所有可能收益加起来,然后矛盾部分能否用最小割表达(本题有两个矛盾,第一个是选还是不选,第二个是i,j有一个不 ...

  6. bzoj 1934最小割

    比较显然的最小割的题,增加节点source,sink,对于所有选1的人我们可以(source,i,1),选0的人我们可以(i,sink,1),然后对于好朋友我们可以连接(i,j,1)(j,i,1),然 ...

  7. bzoj 1497 最小割

    思路:最小割好难想啊,根本想不到.. S -> 用户群 = c[ i ] 基站 -> T = p[ i ] 用户群 -> a[ i ] = inf 用户群 -> b[ i ] ...

  8. BZOJ 1797 最小割(最小割割边唯一性判定)

    问题一:是否存在一个最小代价路径切断方案,其中该道路被切断? 问题二:是否对任何一个最小代价路径切断方案,都有该道路被切断? 现在请你回答这两个问题. 最小割唯一性判定 jcvb: 在残余网络上跑ta ...

  9. BZOJ - 1497 最小割应用

    题意:基站耗费成本,用户获得利益(前提是投入成本),求最大获利 最小割的简单应用,所有可能的收益-(消耗的成本/失去的收益),无穷大边表示冲突,最小割求括号内的范围即可 #include<ios ...

随机推荐

  1. libSVM 简易使用手册

    关于SVM的基础理论知识,可以google这篇文章<SVM的八股简介>,讲解得生动有趣,是入门的极好教材.作为拿来主义者,我更关心怎么用SVM,因此瞄上了台湾林智仁教授提供的libSVM. ...

  2. sql server 数据库模型 备份 恢复 总结 备份脚本

    事务日志是可以基于时间点恢复的,必须在full或bulk_logged模式下 Alter database [DBName] set recover bulk_logged , then the fo ...

  3. Sensor信号输出YUV、RGB、RAW DATA、JPEG【转】

    本文转载自:http://blog.csdn.net/southcamel/article/details/8305873 简单来说,YUV: luma (Y) + chroma (UV) 格式, 一 ...

  4. Java中Properties类的使用

    1.properties介绍 java中的properties文件是一种配置文件,主要用于表达配置信息,文件类型为*.properties,格式为文本文件,文件的内容是格式是"键=值&quo ...

  5. Linux软件管理——yum命令详解

    yum install <softwarename> #安装指定软件 yum remove <softwarename> #卸载指定软件 yum update <soft ...

  6. 处理字符串中的换行,将textarea中的带有换行的字符串变为逗号分隔的写法

    _setMultipleInputValues: function (param) { //Maybe need to modify here for the new parameter //add ...

  7. JavaScript脚本语言基础(三)

    导读: 数学对象(Math) 数组对象(Array) 字符串对象(String) 日期对象(Date) js对象是属性和方法的集合.JavaScript中的所有事物都是对象,如:字符串.数值.数组.函 ...

  8. IOS中两个view的切换

    在ios中,rootview为PassWordViewController,secondview为SecondViewController,实现在rootview中听过一个跳转按钮实现跳转到secon ...

  9. asp.net 关闭子窗体 刷新主窗体

    主窗体************************************************************************************ //原窗口保留,以对话框 ...

  10. H - Solve this interesting problem 分类: 比赛 2015-07-29 21:06 15人阅读 评论(0) 收藏

    Have you learned something about segment tree? If not, don't worry, I will explain it for you.  Segm ...