这是一道写起来比较顺手的题目

没有各种奇怪的细节,基本就是Kruskal和倍增LCA的模板。。

题目大意:对于一个无向带权图,询问两点之间一条路,使得这条路上的最长边最小,输出最小最长边的的值

那么既然要使最长边最短,我们可以先构造一棵最小生成树

由于kruskal已经将边排了序了,所以对于这棵树,每条边都尽量最短了

然后我们再进行lca求出两点路径上的最长边,即为答案

 #include<stdio.h>
 #include<string.h>
 #include<algorithm>
 using namespace std;
 ;
 struct node{
     int u,v,cost,next;
 }e[maxn*],et[maxn*];
 int head[maxn],n,m,K,tot,logn,u,v;
 ],mx[maxn][];

 void insert(int u, int v, int c){
     e[++tot].u=u; e[tot].v=v; e[tot].cost=c; e[tot].next=head[u]; head[u]=tot;
 }

 bool cmp(node a, node b){
     return a.cost<b.cost;
 }

 int find(int x){
     return f[x]==x?x:f[x]=find(f[x]);
 }

 void MST(){
     ; i<=n; i++) f[i]=i;
     ; i<=m; i++){
         int fx=find(et[i].u), fy=find(et[i].v);
         if (fx!=fy){
             f[fy]=fx;
             insert(et[i].u,et[i].v,et[i].cost);
             insert(et[i].v,et[i].u,et[i].cost);
         }
     }
 }

 void dfs(int u, int f, int d, int cost){
     dep[u]=d; fa[u][]=f; mx[u][]=cost;
     ; i<=logn; i++) fa[u][i]=fa[fa[u][i-]][i-];
     ; i<=logn; i++) mx[u][i]=max(mx[u][i-],mx[fa[u][i-]][i-]);
     ; i=e[i].next)
         ,e[i].cost);
 }

 int lca_max(int u, int v){
     ;
     if (dep[u]>dep[v]) swap(u,v);
     while (dep[u]<dep[v]){
         ; i--)
             if (dep[u]<dep[fa[v][i]]){
                 ans=max(ans,mx[v][i]);
                 v=fa[v][i];
             }
         ans=max(ans,mx[v][]);
         v=fa[v][];
     }
     if (u==v) return ans;
     ; i--){
         if (fa[u][i]!=fa[v][i]){
             ans=max(ans,max(mx[v][i],mx[u][i]));
             u=fa[u][i]; v=fa[v][i];
         }
     }
     ans=max(ans,max(mx[u][],mx[v][]));
     return ans;
 }

 int main(){
     scanf("%d%d%d", &n, &m, &K);
     tot=-; memset(head,-,sizeof(head));
     <<logn)<n) logn++;
     ; i<=m; i++)
         scanf("%d%d%d", &et[i].u, &et[i].v, &et[i].cost);
     sort(et+,et++m,cmp);
     MST();
     dfs(,,,);
     while (K--){
         scanf("%d%d", &u, &v);
         printf("%d\n", lca_max(u,v));
     }
     ;
 }

bzoj3732: Network--kruskal最小生成树+LCA的更多相关文章

  1. 【BZOJ3732】 Network Kruskal+倍增lca

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

  2. Kruskal 最小生成树算法

    对于一个给定的连通的无向图 G = (V, E),希望找到一个无回路的子集 T,T 是 E 的子集,它连接了所有的顶点,且其权值之和为最小. 因为 T 无回路且连接所有的顶点,所以它必然是一棵树,称为 ...

  3. 贪心算法(2)-Kruskal最小生成树

    什么是最小生成树? 生成树是相对图来说的,一个图的生成树是一个树并把图的所有顶点连接在一起.一个图可以有许多不同的生成树.一个有 n 个结点的连通图的生成树是原图的极小连通子图,且包含原图中的所有 n ...

  4. Prim和Kruskal最小生成树

    标题: Prim和Kruskal最小生成树时 限: 2000 ms内存限制: 15000 K总时限: 3000 ms描述: 给出一个矩阵,要求以矩阵方式单步输出生成过程.要求先输出Prim生成过程,再 ...

  5. ZOJ 1542 POJ 1861 Network 网络 最小生成树,求最长边,Kruskal算法

    题目连接:problemId=542" target="_blank">ZOJ 1542 POJ 1861 Network 网络 Network Time Limi ...

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

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

  7. POJ 1861:Network(最小生成树&amp;amp;&amp;amp;kruskal)

    Network Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 13266   Accepted: 5123   Specia ...

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

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

  9. POJ 2349 Arctic Network (最小生成树)

    Arctic Network 题目链接: http://acm.hust.edu.cn/vjudge/contest/124434#problem/F Description The Departme ...

随机推荐

  1. 如何安装并简单的使用OwinHost——Katana

    微软OWIN的提出必然会引起一场风暴,而我们作为C#阵营中一份子,自然免不了会卷入其中.OWIN是什么东西,我在这里就不解析了,还不知道是OWIN是什么的读者请打开浏览器,然后搜索即可,中文的英文的应 ...

  2. Prime Generator

    Peter wants to generate some prime numbers for his cryptosystem. Help him! Your task is to generate ...

  3. ASP.NET MVC 简介

    1. ASP.NET MVC 是什么? ASP.NET MVC是微软官方提供的以MVC模式为基础的ASP.NET Web应用程序(Web Application)框架,它由Castle的MonoRai ...

  4. java 深度遍历文件夹中的所有文件

    看标题就知道是什么意思了吧,所以就不多说了,直接贴代码: import java.io.*; public class files { private static void iterateFile( ...

  5. The Number Off of FFF

    X soldiers from the famous “FFF army'' is standing in a line, from left to right. You, as the captai ...

  6. [TCPIP] 传输控制协议 Note

    TCPIP  TCP 传输控制协议 TCP提供一种面向连接的,可靠的字节流服务. 面向连接意味着两个使用TCP的应用在传输数据之前先建立一个TCP连接,这个过程跟打电话相似.在一个TCP连接中仅有两方 ...

  7. AngularJS时间轴指令

    是基于ion.rangeSlider.js,主要代码如下: <link rel="stylesheet" type="text/css" href=&qu ...

  8. 微信小程序上传文件

    wx.chooseImage({ count: 1, // 默认9 sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有 sourc ...

  9. 为 ASP.NET Web API 创建帮助页面(转载)

    转载地址:http://www.asp.net/web-api/overview/creating-web-apis/creating-api-help-pages 当创建web API 时,经常要创 ...

  10. iPhone6手機產品提交了進網申請

    近期,海外投資蘋果公司為iPhone6手機產品提交了進網申請,經電信設備進網檢測機構測試和我部審查,相關產品滿足進網管理要求.根據<電信條例>有關規定,我部依法定程式在法定時限內為蘋果公司 ...