NOIP2013 货车运输(最大生成树,倍增)
NOIP2013 货车运输(最大生成树,倍增)
A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路。每一条道路对车辆都有重量限制,简称限重。现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的情况下,最多能运多重的货物。n=1e4,m=5e4.
首先肯定是跑一个最大生成数辣~跑完以后倍增lca即可。注意kruskal的写法,并查集一定要写对!
#include <cstdio>
#include <algorithm>
using namespace std;
const int maxn=1e4+5, maxm=5e4+5, INF=1e9;
struct Edge{
int fr, to, next, v;
}e[2*maxn], e1[2*maxm];
bool cmp(const Edge &a, const Edge &b){ return a.v>b.v; }
int cnte, fir[maxn];
void addedge(int x, int y, int v){
Edge &ed=e[++cnte];
ed.to=y; ed.next=fir[x]; ed.v=v; fir[x]=cnte;
}
int fa[maxn];
int find(int x){ return fa[x]==x?x:fa[x]=find(fa[x]); }
int f[maxn][17], v[maxn][17]; //f表示不包括自己,上面第2^i个结点,v表示从i开始这个路径的权值
int dep[maxn];
void dfs(int now, int par, int val){ //当前结点 父亲结点 父亲连边的值
f[now][0]=par; v[now][0]=val; dep[now]=dep[par]+1;
for (int i=1; i<17; ++i){
f[now][i]=f[f[now][i-1]][i-1];
v[now][i]=min(v[now][i-1], v[f[now][i-1]][i-1]);
}
for (int i=fir[now]; i; i=e[i].next){
if (e[i].to==par) continue;
dfs(e[i].to, now, e[i].v);
}
}
int n, m, q;
int solve(int x, int y){
if (dep[x]<dep[y]) swap(x, y); int ans=INF;
for (int i=16; i>=0; --i)
if (dep[f[x][i]]>=dep[y]) ans=min(ans, v[x][i]), x=f[x][i];
for (int i=16; i>=0; --i)
if (f[x][i]!=f[y][i]) ans=min(ans, min(v[x][i], v[y][i])), x=f[x][i], y=f[y][i];
if (x!=y) ans=min(ans, min(v[x][0], v[y][0])); //一定要注意两个点是祖孙关系的情况!
return ans;
}
int main(){
scanf("%d%d", &n, &m); int t1, t2, t3;
for (int i=0; i<m; ++i){
scanf("%d%d%d", &t1, &t2, &t3);
e1[i].fr=t1; e1[i].to=t2; e1[i].v=t3;
}
sort(e1, e1+m, cmp);
for (int i=1; i<=n; ++i) fa[i]=i;
for (int i=0; i<m; ++i){ //直接把边都跑一遍就行了!
if (find(e1[i].fr)==find(e1[i].to)) continue;
addedge(e1[i].fr, e1[i].to, e1[i].v);
addedge(e1[i].to, e1[i].fr, e1[i].v);
fa[find(e1[i].fr)]=find(e1[i].to);
}
for (int i=1; i<=n; ++i) if (fa[i]==i) dfs(i, 0, 0); //分成许多个子树
scanf("%d", &q);
for (int i=0; i<q; ++i){
scanf("%d%d", &t1, &t2);
if (find(t1)!=find(t2)){ puts("-1"); continue; }
printf("%d\n", solve(t1, t2));
}
return 0;
}
NOIP2013 货车运输(最大生成树,倍增)的更多相关文章
- $Noip2013/Luogu1967$ 货车运输 最大生成树+倍增$lca$
$Luogu$ $Sol$ 首先当然是构建一棵最大生成树,然后对于一辆货车的起点和终点倍增跑$lca$更新答案就好.记得预处理倍增的时候不仅要处理走了$2^i$步后是那个点,还有这中间经过的路径权值的 ...
- 【NOIP2013】货车运输 最大生成树+倍增
题目大意:给你一张n个点m条边的图,有q次询问,每次让你找出一条从x至y的路径,使得路径上经过的边的最小值最大,输出这个最大的最小值. 显然,经过的路径必然在这张图的最大生成树上. 我们求出这个图的最 ...
- Luogu1967 NOIP2013 货车运输 最大生成树、倍增
传送门 题意:给出一个$N$个节点.$M$条边的图,$Q$次询问,每一次询问两个点之间的所有可行路径中经过的边的边权的最小值中的最大值.$N \leq 10000 , M \leq 50000 , Q ...
- TZOJ 4848 货车运输(最大生成树+倍增lca)
描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的情况下,最多能运多 ...
- [noip2013]货车运输(kruskal + 树上倍增)
描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的情况下,最多能运多 ...
- [Luogu 1967] NOIP2013 货车运输
[Luogu 1967] NOIP2013 货车运输 一年多前令我十分头大的老题终于可以随手切掉了- 然而我这码风又变毒瘤了,我也很绝望. 看着一年前不带类不加空格不空行的清纯码风啊,时光也好像回去了 ...
- NOIP2013 货车运输 (最大生成树+树上倍增LCA)
死磕一道题,中间发现倍增还是掌握的不熟 ,而且深刻理解:SB错误毁一生,憋了近2个小时才调对,不过还好一遍AC省了更多的事,不然我一定会疯掉的... 3287 货车运输 2013年NOIP全国联赛提高 ...
- NOIP2013 货车运输
3.货车运输 (truck.cpp/c/pas) [问题描述] A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货 ...
- Codevs3278[NOIP2013]货车运输
3287 货车运输 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description A 国有 ...
随机推荐
- 机器学习:调整kNN的超参数
一.评测标准 模型的测评标准:分类的准确度(accuracy): 预测准确度 = 预测成功的样本个数/预测数据集样本总数: 二.超参数 超参数:运行机器学习算法前需要指定的参数: kNN算法中的超参数 ...
- 2018年长沙理工大学第十三届程序设计竞赛 H数学考试
链接:https://www.nowcoder.com/acm/contest/96/H来源:牛客网 数学考试 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言6 ...
- AngularJS:路由
ylbtech-AngularJS:路由 1.返回顶部 1. AngularJS 路由 本章节我们将为大家介绍 AngularJS 路由. AngularJS 路由允许我们通过不同的 URL 访问不同 ...
- DCloud-wap2app:杂项
ylbtech-DCloud-wap2app:杂项 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 6.返回顶部 7.返回顶部 8.返回顶部 ...
- ruby on rails 中render的
Ruby rails页面跳转代码如下: 1.render(:text => string) 2.render(:inline => string, [:type => "r ...
- Appium—python_ 安卓手机划屏幕操作
开始的时候 不知道 python_unittest框架的命名规则,导致方法进不去,后来 改变方法名 能获取 # conding=utf- from appium import webdriver im ...
- java 多线程系列---JUC原子类(三)之AtomicLongArray原子类
AtomicLongArray介绍和函数列表 在"Java多线程系列--“JUC原子类”02之 AtomicLong原子类"中介绍过,AtomicLong是作用是对长整形进行原子操 ...
- cygwin选择安装包选项搭建NDK开发环境/配置cygwin的root权限
9.Search是可以输入你要下载的包的名称,能够快速筛选出你要下载的包.那四个单选按钮是选择下边树的样式,默认就行,不用动.View默认是Category,建议改成full显示全部包再查,省的一些包 ...
- 如何边遍历集合边删除元素--使用Iterator中的remove()方法
在遍历集合时,想将符合条件的某些元素删除,开始是用了下面的方法 public static void main(String[] args) throws UnsupportedEncodingExc ...
- JQuery利用css()修改样式后 hover失效的解决办法
执行完代码后发现写在样式表中的hover效果失效,改了好几遍差点重新写函数,后来发现很简单,是优先级的问题,css()中的内容覆盖了之前的样式 只需要在样式后写!important即可解决! .fil ...