●BOZJ 2229 [Zjoi2011]最小割
题链:
http://www.lydsy.com/JudgeOnline/problem.php?id=2229
题解:
首先先去看看这个博客:http://blog.csdn.net/jyxjyx27/article/details/42750833
非常不错的,可以对最小割树有一个简单的感性认识。
由于求最小割树感觉很麻烦,并且本题的点数的数据规模不大,
所以就不需要构造出最小割树,只需要求出所有的 ans[i][j]:i->j的最小割。
即采用分治,求出 n-1个最小割,
并在每次求完最小割后,尝试更新不同集合的点之间的 ans即可。
代码:
#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
#define MAXN 200
#define MAXM 7000
#define INF 0x3f3f3f3f
#define filein(x) freopen(#x".in","r",stdin);
#define fileout(x) freopen(#x".out","w",stdout);
using namespace std;
struct Edge{
int to[MAXM],cap[MAXM],next[MAXM],head[MAXN],ent;
void Init(){
ent=2; memset(head,0,sizeof(head));
}
void Adde(int u,int v,int w){
to[ent]=v; cap[ent]=w; next[ent]=head[u]; head[u]=ent++;
to[ent]=u; cap[ent]=0; next[ent]=head[v]; head[v]=ent++;
}
void reset(){
for(int i=2;i<ent;i+=2){
cap[i]=cap[i^1]=(cap[i]+cap[i^1])/2;
}
}
}E;
bool mark[MAXN];
int a[MAXN],cur[MAXN],d[MAXN],ans[MAXN][MAXN];
int N,M,Q;
bool bfs(int S,int T){
static queue<int> q; int u,v;
memset(d,0,sizeof(d));
d[S]=1; q.push(S);
while(!q.empty()){
u=q.front(); q.pop();
for(int i=E.head[u];i;i=E.next[i]){
v=E.to[i];
if(d[v]||!E.cap[i]) continue;
d[v]=d[u]+1; q.push(v);
}
}
return d[T];
}
int dfs(int u,int reflow,const int &T){
if(u==T||!reflow) return reflow;
int flowout=0,f,v;
for(int &i=cur[u];i;i=E.next[i]){
v=E.to[i];
if(d[v]!=d[u]+1) continue;
f=dfs(v,min(reflow,E.cap[i]),T);
flowout+=f; E.cap[i^1]+=f;
reflow-=f; E.cap[i]-=f;
if(!reflow) break;
}
if(!flowout) d[u]=0;
return flowout;
}
int Dinic(int S,int T){
int flow=0;
while(bfs(S,T)){
memcpy(cur,E.head,sizeof(E.head));
flow+=dfs(S,INF,T);
}
return flow;
}
void dfs(int u){
mark[u]=1;
for(int i=E.head[u];i;i=E.next[i])
if(!mark[E.to[i]]&&E.cap[i]) dfs(E.to[i]);
}
void Partition(int l,int r){
static int tmp[MAXN],S,T,cut;
if(l>=r) return;
E.reset(); S=a[l]; T=a[r];
cut=Dinic(S,T);
memset(mark,0,sizeof(mark)); dfs(S);
for(int i=1;i<=N;i++)
for(int j=1;j<i;j++) if(mark[a[i]]^mark[a[j]])
ans[a[i]][a[j]]=ans[a[j]][a[i]]=min(ans[a[i]][a[j]],cut);
int L=l,R=r;
for(int i=l;i<=r;i++)
if(mark[a[i]]) tmp[L++]=a[i];
else tmp[R--]=a[i];
for(int i=l;i<L;i++) a[i]=tmp[i];
for(int i=r;i>R;i--) a[i]=tmp[i];
Partition(l,L-1);
Partition(R+1,r);
}
int main()
{
filein(mincut); fileout(mincut);
int T; scanf("%d",&T);
while(T--){
E.Init();
memset(ans,0x3f,sizeof(ans));
scanf("%d%d",&N,&M);
for(int i=1;i<=N;i++) a[i]=i;
for(int i=1,u,v,w;i<=M;i++){
scanf("%d%d%d",&u,&v,&w);
E.Adde(u,v,2*w);
}
E.reset(); Partition(1,N);
scanf("%d",&Q);
for(int k=1,c,num;k<=Q;k++){
scanf("%d",&c); num=0;
for(int i=1;i<=N;i++)
for(int j=1;j<i;j++)
if(ans[i][j]<=c) num++;
printf("%d\n",num);
}
puts("");
} return 0;
}
●BOZJ 2229 [Zjoi2011]最小割的更多相关文章
- bzoj 2229 [Zjoi2011]最小割(分治+最小割)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2229 [题意] 回答若干个关于割不超过x的点对数目的询问. [思路] [最小割最多有n ...
- bzoj 2229: [Zjoi2011]最小割
Description 小白在图论课上学到了一个新的概念--最小割,下课后小白在笔记本上写下了如下这段话: "对于一个图,某个对图中结点的划分将图中所有结点分成两个部分,如果结点s,t不在同 ...
- BZOJ.2229.[ZJOI2011]最小割(最小割树)
题目链接 题意:给定一张无向图,求任意两点之间的最小割. 在所有点中任选两个点作为源点\(S\).汇点\(T\),求它们之间的最小割\(ans\),并把原图分成两个点集\(S',T'\),用\(ans ...
- bzoj 2229: [Zjoi2011]最小割【Gomory–Hu tree最小割树】
这个算法详见http://www.cnblogs.com/lokiii/p/8191573.html 求出两两之间最小割之后暴力统计即可 #include<iostream> #inclu ...
- 2229: [Zjoi2011]最小割(最小割树)
Description 小白在图论课上学到了一个新的概念——最小割,下课后小白在笔记本上写下了如下这段话: “对于一个图,某个对图中结点的划分将图中所有结点分成两个部分,如果结点s,t不在同一个部分中 ...
- BZOJ2229: [Zjoi2011]最小割
题解: 真是一道神题!!! 大家还是围观JZP的题解吧(网址找不到了...) 代码: #include<cstdio> #include<cstdlib> #include&l ...
- bzoj千题计划139:bzoj2229: [Zjoi2011]最小割
http://www.lydsy.com/JudgeOnline/problem.php?id=2229 最小割树介绍:http://blog.csdn.net/jyxjyx27/article/de ...
- bzoj2229: [Zjoi2011]最小割(分治最小割+最小割树思想)
2229: [Zjoi2011]最小割 题目:传送门 题解: 一道非常好的题目啊!!! 蒟蒻的想法:暴力枚举点对跑最小割记录...绝对爆炸啊.... 开始怀疑是不是题目骗人...难道根本不用网络流?? ...
- 【BZOJ2229】[ZJOI2011]最小割(网络流,最小割树)
[BZOJ2229][ZJOI2011]最小割(网络流,最小割树) 题面 BZOJ 洛谷 题解 戳这里 那么实现过程就是任选两点跑最小割更新答案,然后把点集划分为和\(S\)联通以及与\(T\)联通. ...
随机推荐
- APP案例分析
产品 蓝叠安卓模拟器 选择理由 看了一眼桌面,就这个比较有意思.现在很多人喜欢玩手游,经常喜欢开个小号搞事情.这时候身边又没有多余的手机,怎么办?安卓模拟器下一个.手机屏幕太小玩起来没意思怎么 ...
- 简单的C语言编译器--语义制导翻译
语法分析是最难写的,而这部分确实最伤脑的.大量的语义动作分析差点把我逼疯. 简而言之,这部分的作用就是在每次归约之后,都进行一些语义动作,最终让我们得到测试程序的三地址码,即中间代码. 1. ...
- ExecutorService,另一种服务,线程
http://heipark.iteye.com/blog/1393847 Executors.newFixedThreadPool和ArrayBlockingQueue一点使用心得 博客 ...
- 用greenlet实现Python中的并发
from greenlet import greenlet def test1(): print 12 gr2.switch() print 34 def test2(): print 56 gr1. ...
- io多路复用(三)
#!/usr/bin/env python # -*- coding:utf-8 -*- import socket sk1 = socket.socket() sk1.bind(('127.0.0. ...
- jquery 表双击某行时,取出某行中各列的数值.
<script> $(function () { $("tr").dblclick(function () { var txt = $("table tr ...
- TCP/IP和HTTP协议代理
TCP/IP协议族 TCP/IP(传输控制协议/网际协议)是用于计算机通信的一个协议族. TCP/IP协议族包括诸如Internet协议(IP).地址解析协议(ARP).互联网控制信息协议(ICMP) ...
- GIT入门笔记(8)-- 查看历史提交记录/根据版本号回到过去或未来
在Git中,用HEAD表示当前版本,也就是最新的提交版本, 上一个版本就是HEAD^, 上上一个版本就是HEAD^^, 往上100个版本写100个^比较容易数不过来,所以写成HEAD~100. Git ...
- maven编译时出现读取XXX时出错invalid LOC header (bad signature)
问题原因 该包没有下载正确. 解决办法 找到该包的目录,删除该包重新下载即可. 重新下载后用maven test一下,红叉消失.
- 新概念英语(1-32)A fine day
新概念英语(1-33)A fine day Where is the Jones family? It is a fine day today. There are some clouds in th ...