Luogu P1967 货车运输
这题是知道了正解做法才写的..
求每两点间最小权值最大的路径,本来我以为要每个点都跑一遍dij(?),后来意识到生成树好像是用来找这个的( ´▽`)
然后我问dtxdalao对不对,他说“我记得这道题好像要用倍增”(我:???剧透会被关进小黑屋的)
其实就是最大生成树是随便建的,然后对于每两点,用倍增求他们的lca,沿途更新最小的边权即为答案
其实我也没怎么debug (i--这种问题就不说了吧)
这题思路还算比较清晰,明白做法之后就分别把几个算法写出来就行了,
注意:lca中最小边权的更新可能在跳到深度相同/同时倍增/最后求lca的路上,所以...反正多更新几次就没错啦w
#include<cstdio>
#include<algorithm>
#include<cmath>
#define MogeKo qwq
using namespace std;
const int maxn = ;
int n,m,q,x,y;
int cnt,head[maxn],to[maxn],nxt[maxn],val[maxn];
int fa[maxn],dpth[maxn],p[maxn][],w[maxn][]; void add(int x,int y,int z) {
to[++cnt] = y;
nxt[cnt] = head[x];
head[x] = cnt;
val[cnt] = z;
} struct edg {
int l,r,c;
} a[maxn]; bool cmp(edg A,edg B) {
return A.c > B.c;
} int getfa(int x) {
if(fa[x] == x)return x;
else return fa[x] = getfa(fa[x]);
} void kruskal() {
sort(a+,a+m+,cmp);
for(int i = ; i <= m; i++) {
int xx = getfa(a[i].l);
int yy = getfa(a[i].r);
if(xx == yy)continue;
fa[xx] = yy;
add(xx,yy,a[i].c);
add(yy,xx,a[i].c);
}
} void dfs(int u,int fa) {
for(int i = ; ( << i) <= dpth[u]; i++) {
p[u][i] = p[p[u][i-]][i-];
w[u][i] = min(w[u][i-],w[p[u][i-]][i-]);
}
for(int i = head[u]; i; i = nxt[i]) {
int v = to[i];
if(v == fa)continue;
dpth[v] = dpth[u]+;
p[v][] = u;
w[v][] = val[i];
dfs(v,u);
}
} int lca(int a,int b) {
int ans = ;
if(dpth[a] < dpth[b])
swap(a,b);
for(int i = log2(dpth[a]); i >= ; i--)
if(dpth[p[a][i]] >= dpth[b]) {
ans = min(ans,w[a][i]);
a = p[a][i];
}
if(a == b)return ans;
for(int i = log2(dpth[a]); i >= ; i--)
if(p[a][i] != p[b][i]) {
ans = min(ans,min(w[a][i],w[b][i]));
a = p[a][i];
b = p[b][i];
}
ans = min(ans,min(w[a][],w[b][]));
return ans;
} int main() {
scanf("%d%d",&n,&m);
for(int i = ; i <= n; i++)
fa[i] = i;
for(int i = ; i <= m; i++)
scanf("%d%d%d",&a[i].l,&a[i].r,&a[i].c);
kruskal();
for(int i = ; i <= n; i++)
if(fa[i] == i){
dpth[i] = ;
dfs(i,);
}
scanf("%d",&q);
while(q--) {
scanf("%d%d",&x,&y);
int xx = getfa(x);
int yy = getfa(y);
if(xx != yy) {
printf("-1\n");
continue;
}
printf("%d\n",lca(x,y));
}
return ;
}
Luogu P1967 货车运输的更多相关文章
- Luogu P1967 货车运输(Kruskal重构树)
P1967 货车运输 题面 题目描述 \(A\) 国有 \(n\) 座城市,编号从 \(1\) 到 \(n\) ,城市之间有 \(m\) 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 \ ...
- LUOGU P1967 货车运输(最大生成树+树剖+线段树)
传送门 解题思路 货车所走的路径一定是最大生成树上的路径,所以先跑一个最大生成树,之后就是求一条路径上的最小值,用树剖+线段树,注意图可能不连通.将边权下放到点权上,但x,y路径上的lca的答案不能算 ...
- Luogu P1967 货车运输 倍增+最大生成树
看见某大佬在做,决定补一发题解$qwq$ 首先跑出最大生成树(注意有可能不连通),然后我们要求的就是树上两点间路径上的最小边权. 我们用倍增的思路跑出来$w[u][j]$,表示$u$与的它$2^j$的 ...
- 洛谷 P1967 货车运输
洛谷 P1967 货车运输 题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在 ...
- P1967 货车运输
P1967 货车运输最大生成树+lca+并查集 #include<iostream> #include<cstdio> #include<queue> #inclu ...
- kruskal - 倍增 - 并查集 - Luogu 1967 货车运输
P1967 货车运输 题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过 ...
- 洛谷P3379lca,HDU2586,洛谷P1967货车运输,倍增lca,树上倍增
倍增lca板子洛谷P3379 #include<cstdio> struct E { int to,next; }e[]; ],anc[][],log2n,deep[],n,m,s,ne; ...
- 【杂题总汇】NOIP2013(洛谷P1967) 货车运输
[洛谷P1967] 货车运输 重做NOIP提高组ing... +传送门-洛谷P1967+ ◇ 题目(copy from 洛谷) 题目描述 A国有n座城市,编号从1到n,城市之间有m条双向道路.每一条道 ...
- [luogu 1967]货车运输
货车运输 题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情 ...
随机推荐
- ViewPager结合Fragment进行无限滑动
实现ViewPager结合Fragment实现无限循环切换,这里也是在适配器里面进行的,当然使用滑动监听也能够实现 import android.support.v4.app.Fragment; im ...
- 使用Redis作为分布式锁的一些注意点
Redis实现分布式锁 最近看分布式锁的过程中看到一篇不错的文章,特地的加工一番自己的理解: Redis分布式锁实现的三个核心要素: 1.加锁 最简单的方法是使用setnx命令.key是锁的唯一标识, ...
- Linux/Unix 中 wheel 组的来源
使用过 Linux/Unix 的朋友应该知道,将用户添加都 wheel用户组,让用户可以通过在命令在前加 sudo 临时获取 root 用户的权限.但是有没有朋友会想知道为何这个用户组要交 wheel ...
- OSWatcher使用过程中小问题解决方法
本文介绍一下在使用OSWatcher过程当中遇到的两个问题的解决方法.如有更好的方法,敬请留言. 1:OSWatcher在配置文件里面设置了参数OSW_COMPRESSION为gzip后,OSWatc ...
- java.lang.NumberFormatException: Infinite or NaN
1.异常提示: java.lang.NumberFormatException: Infinite or NaN 2.原因:无法格式化的数字,此数字要么不是个数字,要么是无穷大的数字,从而导致 B ...
- 利用uWSGI和nginx进行服务器部署
搭建服务器虚拟环境 1)在本机进入虚拟环境,执行命令导出当前需要的所有包. pip freeze > plist.txt 2)通过ftp软件将项目代码和plist.txt文件上传到服务器. 3) ...
- 【PAT】B1011 A+B 和 C
注意数据的范围,使用long long就行了 #include<stdio.h> int main(){ int N;scanf("%d",&N); for(i ...
- python——虚拟环境之virtualenvwrapper-win(windows10,64位)
1 问题描述 当M个项目需要N个版本的python环境配置时(M>N)时,我们没有必要对每个项目都创建一个虚拟环境,只需要创建N个虚拟环境即可.这样节省了大量存储空间(特别是当M远大于N时).但 ...
- MATLAB简易画图
给定一组特殊点,连线作图 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 以成绩隶属函数为例: score.m cj_x1=[ 0.1]; cj_y1= ...
- 关于pycharm中使用charts无法显示图表的问题(属于个人粗心问题)
在练习用charts库对爬取的数据进行数据分析并图表化时遇到一个问题,无法显示图表,如下: 经过重装charts库等一顿折腾后,终于发现一个问题,看这里: def data_gen(type): le ...