题目描述

小白在图论课上学到了一个新的概念——最小割,下课后小白在笔记本上写下了如下这段话:

对于一个图,某个对图中结点的划分将图中所有结点分成两个部分,如果结点 s 和 t 不在同一个部分中,则称这个划分是关于 s,t 的割。对于带权图来说,将所有顶点处在不同部分的边的权值相加所得到的值定义为这个割的容量,而 s,t的最小割指的是在关于 s,t的割中容量最小的割。

现给定一张无向图,小白有若干个形如“图中有多少个无序点对的最小割的容量不超过 x ”的疑问,小蓝虽然很想回答这些问题,但小蓝最近忙着挖木块,于是作为小蓝的好友,你又有任务了。

输入格式

本题有多组测试数据。

第一行一个整数 T,表示测试数据组数。

对于每组测试数据,第一行两个整数 n,m,表示图的点数和边数。

接下来 m 行,每行三个整数 u,v,c表示有一条权为 ccc 的无向边 (u,v)。不保证图中无重边。

接下来一行一个整数 q 表示询问的个数,下面 q 行每行一个整数 x 描述一组询问。

输出格式

对于每一组测试数据输出 q 行,每行一个整数表示对应询问的答案。对于满足条件的点对 (p,q)和点对 (q,p) 只应该在答案中统计一次。

在两组测试数据之间需要输出一行空行。

输入输出样例

输入 #1

1

5 0

1

0

输出 #1

10

说明/提示

对于 100 的数据,1≤T≤10 ,1≤n≤150,0≤m≤30000,$$1 \leq x \leq 2^{31} - 1 $$ ,0≤q≤300

题解

最小割树(或者就是分治) , 每次选出两个点求出他们的最小割 , 在用这个值更新两边的最小割。

这题不难 , 但我还是调了好久(人话:我好弱啊!!!)

注意

1.题里给的是无向图 , 要建双向边 , 网络流如果要建双向边就不用对每个边再建那流量为0的边了。

2.\(ans[i][j]\) 更新时 \(ans[j][i]\) 也得更新啊!!

3.多测清空。

4.每组数组做完之后要输出回车

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<vector>
#include<cstring>
#include<queue>
#include<cmath>
using namespace std;
const int N = 1005 , M = 100100 , inf = 2e9;
inline int read()
{
register int x = 0 , f = 0; register char c = getchar();
while(c < '0' || c > '9') f |= c == '-' , c = getchar();
while(c >= '0' && c <= '9') x = (x << 3) + (x << 1) + c - '0' , c = getchar();
return f ? -x : x;
}
int n , m , S , T , cnt = 1;
int d[N] , vis[N] , head[N] , ans[N][N] , t1[N] , t2[N] , a[N];
struct edge{ int v , nex , c; } e[M];
inline void add(int u , int v , int c) { e[++cnt].v = v; e[cnt].nex = head[u]; e[cnt].c = c; head[u] = cnt; e[++cnt].v = u; e[cnt].nex = head[v]; e[cnt].c = c; head[v] = cnt; return ; } queue<int> q;
bool bfs()
{
memset(d , 0 , sizeof d); d[S] = 1; q.push(S);
while(q.size())
{
int x = q.front(); q.pop();
for(int i = head[x] , v; i ; i = e[i].nex)
{
v = e[i].v; if(d[v] || e[i].c == 0) continue;
d[v] = d[x] + 1; q.push(v);
}
}
return d[T] != 0;
} int dfs(int x , int flow)
{
if(x == T || flow == 0) return flow;
int res = 0 , k;
for(int i = head[x] , v; i ; i = e[i].nex)
{
v = e[i].v; if(e[i].c == 0 || d[v] != d[x] + 1) continue;
k = dfs(v , min(e[i].c , flow));
if(k)
{
e[i].c -= k; e[i^1].c += k; res += k; flow -= k;
if(flow == 0) return res;
}
else d[v] = 0;
}
return res;
} int Dinic()
{
for(int i = 2 ; i <= cnt ; i += 2) e[i].c = e[i^1].c = (e[i^1].c + e[i].c) >> 1;
int ans = 0 , flow;
while(bfs()) while(flow = dfs(S , inf)) ans += flow;
return ans;
} void dfs(int x)
{
vis[x] = 1;
for(int i = head[x] ; i ; i = e[i].nex)
if(e[i].c && !vis[e[i].v]) dfs(e[i].v);
return ;
} void calc(int l , int r)
{
if(l >= r) return ;
memset(vis , 0 , sizeof vis);
S = a[l]; T = a[r]; int flow = Dinic() , cnt1 = 0 , cnt2 = 0; dfs(S);
for(int i = 1 ; i <= n ; ++i) if(vis[i]) for(int j = 1 ; j <= n ; ++j) if(!vis[j]) /*!!!!!!!!!!*/ ans[j][i] = ans[i][j] = min(ans[i][j] , flow);
for(int i = l ; i <= r ; ++i) if(vis[a[i]]) t1[++cnt1] = a[i]; else t2[++cnt2] = a[i];
for(int i = 1 ; i <= cnt1 ; ++i) a[l + i - 1] = t1[i];
for(int i = 1 ; i <= cnt2 ; ++i) a[l + i + cnt1 - 1] = t2[i];
calc(l , l + cnt1 - 1); calc(l + cnt1 , r);
return;
} int solve()
{
n = read(); m = read();
for(int i = 1 , u , v , c ; i <= m ; ++i) u = read() , v = read() , c = read() , add(u , v , c);
for(int i = 1 ; i <= n ; ++i) a[i] = i; memset(ans , 0x3f , sizeof ans);
calc(1 , n);
int Q = read();
while(Q--)
{
int x = read() , res = 0;
for(int i = 1 ; i <= n ; ++i) for(int j = i + 1 ; j <= n ; ++j) if(ans[i][j] <= x) res++;
cout << res << '\n';
}
memset(head , 0 , sizeof head); cnt = 1;
return 0;
} signed main()
{
// freopen("10.in" , "r" , stdin);
int T = read();
while(T --) solve() , cout << '\n';
return 0;
}
/*
2
5 0
1
0
5 0
1
0
*/

P3329 [ZJOI2011]最小割的更多相关文章

  1. BZOJ 2229 / Luogu P3329 [ZJOI2011]最小割 (分治最小割板题)

    题面 求所有点对的最小割中<=c的数量 分析 分治最小割板题 首先,注意这样一个事实:如果(X,Y)是某个s1-t1最小割,(Z,W)是某个s2-t2最小割,那么X∩Z.X∩W.Y∩Z.Y∩W这 ...

  2. BZOJ2229: [Zjoi2011]最小割

    题解: 真是一道神题!!! 大家还是围观JZP的题解吧(网址找不到了...) 代码: #include<cstdio> #include<cstdlib> #include&l ...

  3. 【BZOJ2229】[ZJOI2011]最小割(网络流,最小割树)

    [BZOJ2229][ZJOI2011]最小割(网络流,最小割树) 题面 BZOJ 洛谷 题解 戳这里 那么实现过程就是任选两点跑最小割更新答案,然后把点集划分为和\(S\)联通以及与\(T\)联通. ...

  4. bzoj千题计划139:bzoj2229: [Zjoi2011]最小割

    http://www.lydsy.com/JudgeOnline/problem.php?id=2229 最小割树介绍:http://blog.csdn.net/jyxjyx27/article/de ...

  5. [ZJOI2011]最小割 & [CQOI2016]不同的最小割 分治求最小割

    题面: [ZJOI2011]最小割 [CQOI2016]不同的最小割 题解: 其实这两道是同一道题.... 最小割是用的dinic,不同的最小割是用的isap 其实都是分治求最小割 简单讲讲思路吧 就 ...

  6. 【BZOJ2229】[Zjoi2011]最小割 最小割树

    [BZOJ2229][Zjoi2011]最小割 Description 小白在图论课上学到了一个新的概念——最小割,下课后小白在笔记本上写下了如下这段话: “对于一个图,某个对图中结点的划分将图中所有 ...

  7. bzoj2229: [Zjoi2011]最小割(分治最小割+最小割树思想)

    2229: [Zjoi2011]最小割 题目:传送门 题解: 一道非常好的题目啊!!! 蒟蒻的想法:暴力枚举点对跑最小割记录...绝对爆炸啊.... 开始怀疑是不是题目骗人...难道根本不用网络流?? ...

  8. 【洛谷P3329】 [ZJOI2011]最小割(最小割树)

    洛谷 题意: 给出一个无向图,之后有\(q,q\leq 30\)组询问,每组询问有一个\(x\),回答有多少点对\((a,b)\)其\(a-b\)最小割不超过\(x\). 思路: 这个题做法要最小割树 ...

  9. [bzoj2229][Zjoi2011]最小割_网络流_最小割树

    最小割 bzoj-2229 Zjoi-2011 题目大意:题目链接. 注释:略. 想法: 在这里给出最小割树的定义. 最小割树啊,就是这样一棵树.一个图的最小割树满足这棵树上任意两点之间的最小值就是原 ...

随机推荐

  1. PWA 推送实践

    PWA 推送实践 最近公司内录任务的系统总是忘记录任务,而那个系统又没有通知,所以想要实现一个浏览器的通知功能,免得自己忘记录入任务. 前端实现通知的几种方式 想要实现通知,我们就需要有个客户端,对于 ...

  2. NPM install -save 和 -save-dev 区别

    最近在写Node程序的时候,突然对 npm install 的-save和-save-dev 这两个参数的使用比较混乱.其实博主在这之前对这两个参数的理解也是模糊的,各种查资料和实践后对它们之间的异同 ...

  3. StarUML之二、StarUML初识

    为什么用StarUML UML建模工具比较常见的PowerDesigner ROSE StarUML starUML-开源免费(1-2百M),PowerDesigner-精细和一体化(6-7百M),R ...

  4. HA: Chanakya Vulnhub Walkthrough

    靶机链接: https://www.vulnhub.com/entry/ha-chanakya,395/ 网络主机探测: 主机端口扫描: nmap -p- -sC -sV 10.10.202.136 ...

  5. No mapping found for HTTP request with URI [/SLSaleSystem/js/jquery.dataTables.min.js] in DispatcherServlet with name 'spring' 静态资源文件访问不到,无解!!!!!!!

    报错信息:   网上三种修改 web.xml 文件方法尝试未果 尝试未果:<mvc:default-servlet-handler/> 尝试未果:方法2:直接告诉spring,这个你就得这 ...

  6. Spark应用开发调优要点总结

    调试Spark应用性能的时候,首先应该理解spark是如何工作以及你的spark应用需要何种类型的资源.比如说,机器学习相关的spark应用更依赖cpu计算能力,ETL应用更依赖I/O能力,以此进行有 ...

  7. centos7下NAT模式下设置静态ip

    1.在虚拟网络编辑器下查看子网IP.子网掩码以及网关 2.在Linux系统中进入 /etc/sysconfig/network-scripts目录下,编辑ifcfg-ens33文件,改成下面的内容: ...

  8. Ajax工作原理及优缺点

    1. Ajax是什么? 全称是 asynchronous javascript and xml,是已有技术的组合,主要用来实现客户端与服务器端的异步通信效果(无需重新加载整个网页的情况下),实现页面的 ...

  9. mybatis 配置--->确认jar包是否正确

    mybatis 配置之前,首先要确保服务器jar包是否成功 配置jar包如下添加mybaties-3.5.2. jar, maven 的 pom.xml 配置如下,查看配置是否成功见 如上分类 Mav ...

  10. 嵌入式设备sqlite库移植和使用

    1]官网下载sqlite-autoconf-3300100.tar.gz,网址https://www.sqlite.org/download.html,2]解压:tar zxvf sqlite-aut ...