Description

sideman做好了回到Gliese 星球的硬件准备,但是sideman的导航系统还没有完全设计好。为了方便起见,我们可以认为宇宙是一张有\(N\) 个顶点和\(M\) 条边的带权无向图,顶点表示各个星系,两个星系之间有边就表示两个星系之间可以直航,而边权则是航行的危险程度。

sideman 现在想把危险程度降到最小,具体地来说,就是对于若干个询问(A, B),sideman 想知道从顶点\(A\) 航行到顶点\(B\) 所经过的最危险的边的危险程度值最小可能是多少。作为sideman 的同学,你们要帮助sideman 返回家园,兼享受安全美妙的宇宙航行。所以这个任务就交给你了。

Input

第一行包含两个正整数\(N\) 和\(M\),表示点数和边数。

之后 \(M\) 行,每行三个整数\(A\),$B \(和\)L\(,表示顶点\)A$ 和\(B\) 之间有一条边长为\(L\) 的边。顶点从\(1\) 开始标号。

下面一行包含一个正整数 \(Q\),表示询问的数目。

之后 \(Q\) 行,每行两个整数\(A\) 和\(B\),表示询问\(A\) 和\(B\) 之间最危险的边危险程度的可能最小值。

Output

对于每个询问, 在单独的一行内输出结果。如果两个顶点之间不可达, 输出\(impossible\)。

woc这不是\(Noip\ 2013\)货车运输.

切掉!

显然,我们可以发现.想要让一些顶点联通,并且让最危险的边的危险程度值最小。

优先想到了\(Kruskal\).

首先\(Kruckal\)建树。

如何求两点间的距离?带权\(LCA\)即可.

如果两点不在一颗树,要输出\(impossible\)!!

刚开始输出错了

注意如果写两个结构体的话,对其中一个\(Sort\)(建树)的话,不要结构体中重载\(<\)

代码

#include<cstdio>
#include<algorithm>
#include<cctype>
#define R register
#define N 100008
using namespace std;
inline void in(int &x)
{
int f=1;x=0;char s=getchar();
while(!isdigit(s)){if(s=='-')f=-1;s=getchar();}
while(isdigit(s)){x=x*10+s-'0';s=getchar();}
x*=f;
}
int n,m,head[N],tot,q;
int fa[N],cnt,depth[N],f[N][21],gw[N][21];
struct cod{int u,v,w;}edge[300010],tree[300010];
inline bool ccp(const cod&a,const cod&b)
{
return a.w<b.w;
}
int find(int x){return fa[x]==x ? x : fa[x]=find(fa[x]);}
inline void add(int x,int y,int z)
{
edge[++tot].u=head[x];
edge[tot].v=y;
edge[tot].w=z;
head[x]=tot;
}
inline void kruskal()
{
for(R int i=1;i<=n;i++)fa[i]=i;
sort(tree+1,tree+m+1,ccp);
for(R int i=1;i<=m;i++)
{
int u=tree[i].u,v=tree[i].v,w=tree[i].w;
int fu=find(u),fv=find(v);
if(fu==fv)continue;
add(u,v,w);add(v,u,w);
fa[fu]=fv;cnt++;
if(cnt==n-1)break;
}
return ;
}
void dfs(int u,int fat,int dis)
{
depth[u]=depth[fat]+1;
gw[u][0]=dis;f[u][0]=fat;
for(R int i=1;(1<<i)<=depth[u];i++)
{
f[u][i]=f[f[u][i-1]][i-1];
gw[u][i]=max(gw[u][i-1],gw[f[u][i-1]][i-1]);
}
for(R int i=head[u];i;i=edge[i].u)
{
if(edge[i].v==fat)continue;
dfs(edge[i].v,u,edge[i].w);
}
}
inline int lca(int x,int y)
{
int res=-214748364;
if(depth[x]>depth[y])swap(x,y);
for(R int i=20;i>=0;i--)
if(depth[x]+(1<<i)<=depth[y])
res=max(res,gw[y][i]),y=f[y][i];
if(x==y)return res;
for(R int i=20;i>=0;i--)
{
if(f[x][i]==f[y][i])continue;
res=max(res,gw[x][i]);
res=max(res,gw[y][i]);
x=f[x][i],y=f[y][i];
}
return max(max(res,gw[x][0]),gw[y][0]);
}
int main()
{
in(n),in(m);
for(R int i=1;i<=m;i++)
in(tree[i].u),in(tree[i].v),in(tree[i].w);
kruskal();
dfs(1,0,0);
in(q);
for(R int i=1,x,y;i<=q;i++)
{
in(x),in(y);
R int fx=find(x),fy=find(y);
if(fx!=fy)puts("impossible");
else printf("%d\n",lca(x,y));
}
}

Kruskal+LCA【p2245】 星际导航的更多相关文章

  1. 洛谷 P2245 星际导航 解题报告

    P2245 星际导航 题目描述 sideman做好了回到Gliese 星球的硬件准备,但是sideman的导航系统还没有完全设计好.为了方便起见,我们可以认为宇宙是一张有N 个顶点和M 条边的带权无向 ...

  2. 【luogu P2245 星际导航】 题解

    题目链接:https://www.luogu.org/problemnew/show/P2245 = 货车运输 被逼着写过mst+lca 后来成了mst+树剖 #include <cstdio& ...

  3. P2245 星际导航

    题目描述 sideman 做好了回到 Gliese星球的硬件准备,但是 sideman 的导航系统还没有完全设计好.为了方便起见,我们可以认为宇宙是一张有 N 个顶点和 M 条边的带权无向图,顶点表示 ...

  4. P2245 星际导航 瓶颈路

    \(\color{#0066ff}{ 题目描述 }\) sideman 做好了回到 \(\text{Gliese}\) 星球的硬件准备,但是 \(\text{sideman}\) 的导航系统还没有完全 ...

  5. [LUOGU] P2245 星际导航

    题目描述 sideman做好了回到Gliese 星球的硬件准备,但是sideman的导航系统还没有完全设计好.为了方便起见,我们可以认为宇宙是一张有N 个顶点和M 条边的带权无向图,顶点表示各个星系, ...

  6. [洛谷P2245]星际导航

    题目大意:有一张n点m边的带权无向图,和一些问题,每次询问两个点之间的路径的最大边权最小是多少. 解题思路:同NOIP2013货车运输,只是数据增大,大变成小,小变成大了而已.所以具体思路见货车运输. ...

  7. 最小生成树+LCA【洛谷 P2245】 星际导航

    [洛谷 P2245] 星际导航 题目描述 sideman做好了回到Gliese 星球的硬件准备,但是sideman的导航系统还没有完全设计好.为了方便起见,我们可以认为宇宙是一张有N 个顶点和M 条边 ...

  8. Luogu 2245 星际导航(最小生成树,最近公共祖先LCA,并查集)

    Luogu 2245 星际导航(最小生成树,最近公共祖先LCA,并查集) Description sideman做好了回到Gliese 星球的硬件准备,但是sideman的导航系统还没有完全设计好.为 ...

  9. 【洛谷P2245】星际导航

    题面 题解 \(kruskal\)重构树板子题??(大雾 因为重构树上两点之间的\(LCA\)的权值就是原图上最小生成树上的瓶颈. 所以建个重构树,跑\(LCA\)即可. 代码 #include< ...

随机推荐

  1. WPF and Silverlight.ComboBox 如何通过 Binding IsDropDownOpen 实现下拉菜单展开

    In the WPF example the Popup and the ToggleButton (the arrow on the right) are bound with the proper ...

  2. Java线程的两种实现形式

    一.创建线程的第一种方式:继承Thread类 class Demo extends Thread{ @Override public void run() { super.run(); for(int ...

  3. 软工实践 - 第十三次作业 Alpha 冲刺 (4/10)

    队名:起床一起肝活队 组长博客:https://www.cnblogs.com/dawnduck/p/9980005.html 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去 ...

  4. POJ A-Wireless Network

    http://poj.org/problem?id=2236 An earthquake takes place in Southeast Asia. The ACM (Asia Cooperated ...

  5. Java获取当前服务器IP实现

    package hope.ipaddress.demo; import java.net.InetAddress; import java.net.NetworkInterface; import j ...

  6. 研华 FWA-3231 单路E3平台

    研华 FWA-3231 单路E3平台 服务器主板上芯片组与处理器的适配参考

  7. [AtCoder ARC103A]/\/\/\/

    题目大意:给你一串长度为$n$的序列,要求把这个序列变成$abab\dots abab$的形式,且$a\not =b$,问最少要改几个数字 题解:求出奇偶位上前二多的数字就判断一下就行了 卡点:无 C ...

  8. BZOJ2535 [Noi2010]Plane 航空管制 【贪心 + 堆】

    题目链接 BZOJ2535 题解 航班之间的关系形成了一个拓扑图 而且航班若要合法,应尽量早出发 所以我们逆拓扑序选点,能在后面出发的尽量后面出发,不会使其它点变得更劣,容易知是正确的 第二问只需枚举 ...

  9. [转]Linux下阅读源代码:(g)vim+Taglist+ctags

      Linux下阅读源代码的方法很多,聪明人从标题应该就可以知道,需要(g)vim+Taglist+ctags.3者配合,真是珠联璧合,功力无限啊! vim/gvim什么是vim/gvim,如果看官连 ...

  10. 《机器学习实战》读书笔记—k近邻算法c语言实现(win下)

    #include <stdio.h> #include <io.h> #include <math.h> #include <stdlib.h> #de ...