货车运输

题目描述

\(A\) 国有 \(n\) 座城市,编号从 \(1\) 到 \(n\) ,城市之间有 \(m\) 条双向道路。每一条道路对车辆都有重量限制,简称限重。

现在有 \(q\) 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的情况下,最多能运多重的货物。

输入格式

第一行有两个用一个空格隔开的整数 \(n,m\) ,表示 \(A\) 国有 \(n\) 座城市和 \(m\) 条道路。

接下来 \(m\) 行每行三个整数 \(x,y,z\) ,每两个整数之间用一个空格隔开,表示从 \(x\) 号城市到 \(y\) 号城市有一条限重为 \(z\) 的道路。

注意: \(x≠y\) ,两座城市之间可能有多条道路 。

接下来一行有一个整数 \(q\) ,表示有\(q\)辆货车需要运货。

接下来 \(q\) 行,每行两个整数 \(x,y\) ,之间用一个空格隔开,表示一辆货车需要从 \(x\) 城市运输货物到 \(y\) 城市,保证 \(x≠y\)

输出格式

共有 \(q\) 行,每行一个整数,表示对于每一辆货车,它的最大载重是多少。

如果货车不能到达目的地,输出 \(−1\) 。

输入输出样例

输入

4 3
1 2 4
2 3 3
3 1 1
3
1 3
1 4
1 3

输出

3
-1
3

说明/提示

对于 \(30%\) 的数据, \(1≤n<1000,1≤m<10000,1≤q<1000\);

对于 \(60%\) 的数据, \(1≤n<1000,1≤m<5×10^4,1≤q<1000\) ;

对于 \(100%\) 的数据, \(1≤n<10^4,1≤m<5×10^4,1≤q<3×10^4,0≤z≤10^5\) 。

思路

这道题思路并不难想,最大生成树加上lca,首先把跑一遍kruskal,建一个最大生成树,然后再用lca求最近公共祖先,再搜一遍很简单就可以求出来最小的承重,直接上代码吧。

代码实现

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=1e4+10; struct Edge{//前向星
int to,nxt,val,fro;
bool operator <(const Edge &A)const{
return val>A.val;
}
}E[10*N],e[10*N]; int h[N],idx; void Ins(int a,int b,int c){//建边
e[++idx].to = b; e[idx].nxt = h[a];h[a] = idx;e[idx].val = c;
} int n,m;
int f[N]; int find(int x){//求祖先
return f[x] == x ? x: (f[x] = find(f[x]));
} void Kruskal(){//建最大生成树
sort(E+1, E+m+1);
for(int i = 1; i <= n; i++)
f[i] = i;
for(int i = 1; i <= m; i++){
int u = E[i].fro,v = E[i].to,w = E[i].val;
if(find(u) != find(v)){
f[find(u)] = find(v);Ins(u,v,w);Ins(v,u,w);
}
}
} int p[N][30],dep[N],Min[N][30]; void dfs(int x){//搜索
for(int i = 0; p[x][i]; i++){
p[x][i+1] = p[p[x][i]][i];
Min[x][i+1] = min(Min[x][i],Min[p[x][i]][i]);
}
for(int i = h[x]; i; i = e[i].nxt){
int v = e[i].to;
if(v == p[x][0]) continue;
dep[v] = dep[x]+1;
p[v][0] = x;
Min[v][0] = e[i].val;
dfs(v);
}
} int lca(int x,int y){//求最近公共祖先
if(find(x) != find(y)) return -1;
if(dep[x] < dep[y]) swap(x,y);
int d = dep[x] - dep[y];
int res = 0x7f7f7f7f;
for(int i = 0; d; i++ , d >>= 1){
if(d & 1){
res = min(res, Min[x][i]);
x = p[x][i];
}
}
if(x == y) return res;
for(int i = 24; i >= 0; i--){
if(p[x][i] != p[y][i]){
res = min(res, min(Min[x][i], Min[y][i]));
x = p[x][i];y = p[y][i];
}
}
res = min(res, min( Min[x][0], Min[y][0] ) );
return res;
} int main(){
memset(Min, 0x7f, sizeof(Min));
scanf("%d%d", &n, &m);
for(int i = 1; i <= m; i++)
scanf("%d%d%d", &E[i].fro, &E[i].to, &E[i].val);
Kruskal();
int q;
scanf("%d", &q);
for(int i = 1; i <= n; i++)
if(! dep[i]) dfs(i);
while(q--){
int a,b;
scanf("%d%d", &a, &b);
printf("%d\n", lca(a,b));
}
}

代码并不是很难写,并不过多解释了。

火车运输(最大生成树+lca) 洛谷P1967的更多相关文章

  1. 洛谷P3379lca,HDU2586,洛谷P1967货车运输,倍增lca,树上倍增

    倍增lca板子洛谷P3379 #include<cstdio> struct E { int to,next; }e[]; ],anc[][],log2n,deep[],n,m,s,ne; ...

  2. 【题解】洛谷P1967 [NOIP2013TG] 货车运输(LCA+kruscal重构树)

    洛谷P1967:https://www.luogu.org/problemnew/show/P1967 思路 感觉2013年D1T3并不是非常难 但是蒟蒻还是WA了一次 从题目描述中看出每个点之间有许 ...

  3. 洛谷 P1967 货车运输

    洛谷 P1967 货车运输 题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在 ...

  4. 【题解】【洛谷 P1967】 货车运输

    目录 洛谷 P1967 货车运输 原题 题解 思路 代码 洛谷 P1967 货车运输 原题 题面请查看洛谷 P1967 货车运输. 题解 思路 根据题面,假设我们有一个普通的图: 作图工具:Graph ...

  5. 【杂题总汇】NOIP2013(洛谷P1967) 货车运输

    [洛谷P1967] 货车运输 重做NOIP提高组ing... +传送门-洛谷P1967+ ◇ 题目(copy from 洛谷) 题目描述 A国有n座城市,编号从1到n,城市之间有m条双向道路.每一条道 ...

  6. 洛谷P1967 货车运输

    题目描述 \(A\)国有\(n\)座城市,编号从\(1\)到\(n\),城市之间有\(m\)条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有\(q\)辆货车在运输货物, 司机们想知道每辆车在 ...

  7. Codevs 3287 货车运输 == 洛谷P1967

    3287 货车运输 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description A 国有 n 座城市,编 ...

  8. 洛谷—— P1967 货车运输 || COGS——C 1439. [NOIP2013]货车运输

    https://www.luogu.org/problem/show?pid=1967#sub  ||  http://www.cogs.pro/cogs/problem/problem.php?pi ...

  9. [洛谷 P1967] 货车运输 (最大生成树 lca)

    题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下,最多 ...

随机推荐

  1. FTP配置多用户多目录多权限

    环境介绍 根据开发的需求 要求创建FTP服务器,把前端和后端分开用不同的FTP账号 系统环境 centos 7.4 selinux 关闭 防火墙关闭 安装FTP 很简单就一条命令 yum instal ...

  2. @Component、@Service、@Controller、@Rrepository说明

    自己开发了一个股票智能分析软件,功能很强大,需要的点击下面的链接获取: https://www.cnblogs.com/bclshuai/p/11380657.html 1       Spring容 ...

  3. js循环练习

    var a=1; while(a>0){ var b=prompt('input number'); if(b>a){ alert('big'); } else if(b<a){ a ...

  4. layui导出表格的两种方法

    一.不熟悉layui小白使用方法 1.引入如下js文件: 2.编写如下函数: 3.表格ID要与函数取值保持一致即可,再就是自定义一个按钮触发事件 二.引入插件使用方法 1.layui官网下载插件包: ...

  5. kafka基本概念和hello world搭建

    什么是kafka? Kafka是由Apache软件基金会开发的一个开源流处理平台,由Scala和Java编写.Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者在网站中的所有动作流数据 ...

  6. 一文读懂Redis的四种模式,单机、主从、哨兵、集群

    少点代码,多点头发 本文已经被GitHub收录,欢迎大家踊跃star 和 issues. https://github.com/midou-tech/articles 入职第一周,我被坑了 最近刚入职 ...

  7. Spark读取Hbase中的数据

    大家可能都知道很熟悉Spark的两种常见的数据读取方式(存放到RDD中):(1).调用parallelize函数直接从集合中获取数据,并存入RDD中:Java版本如下: JavaRDD<Inte ...

  8. (九)HttpClient获取cookies

    原文链接:https://blog.csdn.net/cheny1p1ng/article/details/90780024 旧版本DefaultHttpClient 使用getCookieStore ...

  9. 在Unix系统中执行可执行文件

    这篇文章是我在一个叫做Charlotte数据挖掘的公众号上看到的文章,文首提到转载自"朱小厮的博客",当我今天执行一个自己编译的可执行文件后的运行阶段想到了这篇文章,直接一次成功. ...

  10. idea创建项目

    选项详解如下: Create New Project:创建一个新的工程.Import Project:导入一个现有的工程.Open:打开一个已有工程.比如:可以打开 Eclipse 项目.Check ...