题目大意:给定一个n个点m条边的无向连通图,k次询问两点之间所有路径中最长边的最小值
NOIP2013 货车运输,几乎就是原题。。。只不过最小边最大改成了最大边最小。。。
首先看到最大值最小第一反应二分答案 但是二分答案O(kmlogn)明显做不了 这里我们考虑最小生成树
先生成一棵最小生成树,然后每次询问利用倍增LCA求出路径上的最大权值即可
本蒟蒻居然把LCA写挂了。。。 而且样例还过了。。。 伤不起啊。。。
90%达成 剩下一道刷点啥呢。。。
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
struct edge{
int x,y,f;
bool operator < (const edge &y) const
{
return f < y.f;
}
}edges[30300];
struct abcd{
int to,f,next;
}table[30300];
int head[15100],tot;
int n,m,k;
int fa[15100][20],f_max[15100][20],dpt[15100];
int belong[15100];
int find(int x)
{
if(!belong[x]||belong[x]==x)
return belong[x]=x;
return belong[x]=find(belong[x]);
}
void add(int x,int y,int z)
{
table[++tot].to=y;
table[tot].f=z;
table[tot].next=head[x];
head[x]=tot;
}
void dfs(int x)
{
int i;