3732: Network

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 2812  Solved: 1363
[Submit][Status][Discuss]

Description

给你N个点的无向图 (1 <= N <= 15,000),记为:1…N。 
图中有M条边 (1 <= M <= 30,000) ,第j条边的长度为: d_j ( 1 < = d_j < = 1,000,000,000).

现在有 K个询问 (1 < = K < = 20,000)。 
每个询问的格式是:A B,表示询问从A点走到B点的所有路径中,最长的边最小值是多少?

Input

第一行: N, M, K。 
第2..M+1行: 三个正整数:X, Y, and D (1 <= X <=N; 1 <= Y <= N). 表示X与Y之间有一条长度为D的边。 
第M+2..M+K+1行: 每行两个整数A B,表示询问从A点走到B点的所有路径中,最长的边最小值是多少?

Output

对每个询问,输出最长的边最小值是多少。

Sample Input

6 6 8
1 2 5
2 3 4
3 4 3
1 4 8
2 5 7
4 6 2
1 2
1 3
1 4
2 3
2 4
5 1
6 2
6 1

Sample Output

5
5
5
4
4
7
4
5

HINT

1 <= N <= 15,000

1 <= M <= 30,000

1 <= d_j <= 1,000,000,000

1 <= K <= 15,000


Solution

看到题想到的是前几年noip考的货车运输,就是建出最大生成树再链剖+线段树求链上最小边即可,学习了一波$Kruskal$重构树后,整道题就直接变成最大生成树+求LCA了!

这道题是模板了,大佬%%%写的相当清楚了,在最小生成树连接两个块时,新建一个点,作为两个块最远祖先(并查集中)的父亲节点,把这条边的权值下放到新建节点的点权,因为这条边就是连接两个块的最长边权的最小值,所以每次询问返回两个点的LCA的点权值即可。

再也不用复杂的线段树或者倍增啦!!!

Code

#include<bits/stdc++.h>
using namespace std; int n, m, k; struct Node {
int u, v, nex, w;
} Edge1[], Edge[];
bool cmp(Node a, Node b) { return a.w < b.w; } int stot1;
void add1(int u, int v, int w) {
Edge1[++stot1] = (Node) {u, v, , w};
} int stot, h[];
void add(int u, int v) {
Edge[++stot] = (Node) {u, v, h[u], };
h[u] = stot;
} int u_fa[];
int find(int u) {
if(u != u_fa[u]) u_fa[u] = find(u_fa[u]);
return u_fa[u];
} int t, val[];
void Kruskal() {
for(int i = ; i <= n * ; i ++) u_fa[i] = i;
t = n;
for(int i = ; i <= m; i ++) {
int u = Edge1[i].u, v = Edge1[i].v, w = Edge1[i].w;
int uu = find(u), vv = find(v);
if(uu != vv) {
u_fa[uu] = ++ t; u_fa[vv] = t;
add(t, uu); add(t, vv); val[t] = w;
}
}
} int siz[], fa[], son[], dep[];
void dfs1(int u, int ff) {
fa[u] = ff; siz[u] = ; dep[u] = dep[ff] + ;
for(int i = h[u]; i; i = Edge[i].nex) {
int v = Edge[i].v;
if(v == ff) continue;
dfs1(v, u);
siz[u] += siz[v];
if(siz[v] > siz[son[u]]) son[u] = v;
}
} int top[];
void dfs2(int u, int tp) {
top[u] = tp;
if(son[u]) dfs2(son[u], tp);
for(int i = h[u]; i; i = Edge[i].nex) {
int v = Edge[i].v;
if(v == son[u] || v == fa[u]) continue;
dfs2(v, v);
}
} int LCA(int u, int v) {
if(find(u) != find(v)) return ;
while(top[u] != top[v]) {
if(dep[top[u]] < dep[top[v]]) swap(u, v);
u = fa[top[u]];
}
if(dep[u] < dep[v]) swap(u, v);
return val[v];
} int main() {
scanf("%d%d%d", &n, &m, &k);
for(int i = ; i <= m; i ++) {
int u, v, w;
scanf("%d%d%d", &u, &v, &w);
add1(u, v, w);
}
sort(Edge1 + , Edge1 + + m, cmp);
Kruskal();
for(int i = ; i <= t; i ++)
if(!dep[i]) {
dfs1(u_fa[i], ); dfs2(u_fa[i], u_fa[i]);
}
for(int i = ; i <= k; i ++) {
int u, v;
scanf("%d%d", &u, &v);
printf("%d\n", LCA(u, v));
}
return ;
}

【BZOJ】3732: Network【Kruskal重构树】的更多相关文章

  1. [bzoj 3732] Network (Kruskal重构树)

    kruskal重构树 Description 给你N个点的无向图 (1 <= N <= 15,000),记为:1-N. 图中有M条边 (1 <= M <= 30,000) ,第 ...

  2. BZOJ 3732: Network Kruskal 重构树

    模板题,练练手~ Code: #include <cstdio> #include <algorithm> #define N 80000 #define setIO(s) f ...

  3. 【BZOJ 3732】 Network Kruskal重构树+倍增LCA

    Kruskal重构树裸题, Sunshine互测的A题就是Kruskal重构树,我通过互测了解到了这个神奇的东西... 理解起来应该没什么难度吧,但是我的Peaks连WA,,, 省选估计要滚粗了TwT ...

  4. BZOJ3732: Network(Kruskal重构树)

    题意 Link 给出一张$n$个点的无向图,每次询问两点之间边权最大值最小的路径 $n \leqslant 15000, m \leqslant 30000, k \leqslant 20000$ S ...

  5. BZOJ 3732 Network Kruskal+倍增LCA

    题目大意:给定一个n个点m条边的无向连通图.k次询问两点之间全部路径中最长边的最小值 NOIP2013 货车运输.差点儿就是原题...仅仅只是最小边最大改成了最大边最小.. . 首先看到最大值最小第一 ...

  6. Kruskal重构树+LCA || BZOJ 3732: Network

    题面:https://www.lydsy.com/JudgeOnline/problem.php?id=3732 题解:Kruskal重构树板子 代码: #include<cstdio> ...

  7. BZOJ 3732 Network 【模板】kruskal重构树

    [题解] 首先,我们可以发现,A到B的所有路径中,最长边的最小值一定在最小生成树上.我们用Kruskal最小生成树时,假设有两个点集U,V,若加入一条边w(u,v)使U,V联通,那么w就是U中每个点到 ...

  8. Kruskal重构树学习笔记+BZOJ3732 Network

    今天学了Kruskal重构树,似乎很有意思的样子~ 先看题面: BZOJ 题目大意:$n$ 个点 $m$ 条无向边的图,$k$ 个询问,每次询问从 $u$ 到 $v$ 的所有路径中,最长的边的最小值. ...

  9. BZOJ 3551: [ONTAK2010]Peaks加强版 [Kruskal重构树 dfs序 主席树]

    3551: [ONTAK2010]Peaks加强版 题意:带权图,多组询问与一个点通过边权\(\le lim\)的边连通的点中点权k大值,强制在线 PoPoQQQ大爷题解传送门 说一下感受: 容易发现 ...

随机推荐

  1. JAVA记录-Servlet RequestDispatcher请求转发

    RequestDispatcher接口提供将请求转发送到另一个资源的功能,它可能是html,servlet或jsp等. 此接口也可用于包括另一资源的内容.它是servlet协作的一种方式. 在Requ ...

  2. POJ 3710 无向图简单环树上删边

    结论题,这题关键在于如何转换环,可以用tarjan求出连通分量后再进行标记,也可以DFS直接找到环后把点的SG值变掉就行了 /** @Date : 2017-10-23 19:47:47 * @Fil ...

  3. 关于System.getProperty("java.io.tmpdir");的输出,及System.getProperty();参数

    1,首先来介绍下System.getProperty("java.io.tmpdir")输出因为这个输出有点特殊. 理论介绍:他是获取系统临时目录.可以是window的temp,l ...

  4. Linux - awk 文本处理工具四

    awk 常用示例 获取本机 IP 方式 /sbin/ifconfig |awk -v RS="Bcast:" '{print $NF}'|awk -F: '/addr/{print ...

  5. HTTP1.0 HTTP 1.1 HTTP 2.0主要区别

      HTTP1.0 HTTP 1.1主要区别 长连接 HTTP 1.0需要使用keep-alive参数来告知服务器端要建立一个长连接,而HTTP1.1默认支持长连接. HTTP是基于TCP/IP协议的 ...

  6. mybatis开发dao的方法——(三)

    ------------------------1.    SqlSession使用范围------------------- 1.1     SqlSessionFactoryBuilder 通过S ...

  7. linux笔记_day11_shell编程

    1.条件测试类型: 整数测试 字符测试 文件测试 条件测试的表达式: [ expression ] 必须有空格 [[ expression ]] test expression 整数比较 : -eq  ...

  8. Jquery ajax json 不执行success的原因 坑爹

    最近在看jQuery的API文档,在使用到jQuery的ajax时,如果指定了dataType为json,老是不执行success回调,而是执行了error回调函数,极度郁闷.后面改为1.2.6版本可 ...

  9. C# 每月第一天和最后一天

    //每月第一天 - DateTime.Now.Day); //每月最后一天 var endTime=DateTime.Now.AddDays(1 - DateTime.Now.Day).AddMont ...

  10. dubbo启动报错failed to bind nettyserver on

    dubbo报错 今天启动项目的时候,关掉了custom服务, <dubbo:consumer check="false"/> 并且关掉了spring的elastic-j ...