描述

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

格式

输入格式

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

接下来 m 行每行 3 个整数 x、y、z,每两个整数之间用一个空格隔开,表示从 x 号城市到 y 号城市有一条限重为 z 的道路。注意:x 不等于 y,两座城市之间可能有多条道路。

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

接下来 q 行,每行两个整数 x、y,之间用一个空格隔开,表示一辆货车需要从 x 城市运输货物到 y 城市,注意:x 不等于 y。

输出格式

输出共有 q 行,每行一个整数,表示对于每一辆货车,它的最大载重是多少。如果货车不能到达目的地,输出-1。

样例1

样例输入1

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

样例输出1

 
3
-1
3

限制

每个测试点1s。

提示

对于 30%的数据,0 < n < 1,000,0 < m < 10,000,0 < q < 1,000; 
对于 60%的数据,0 < n < 1,000,0 < m < 50,000,0 < q < 1,000; 
对于 100%的数据,0 < n < 10,000,0 < m < 50,000,0 < q < 30,000,0 ≤ z ≤ 100,000。

因为货车要运输最大货物,必须在整张图的最大生成树上选边,可以想到kruskal算法,但此时若要对每一个询问进行一次遍历的话需要 O(mn) 的时间复杂度,那么就需要把答案预先处理出来。

RMQ问题的ST算法 是用 d(i, j) 表示 从 i 开始 长度为 2^j 的一段元素之间的最小值

那么 d(i, j) = min{d(i ,j - 1), d(i + 2 ^ (j - 1), j - 1)}; 从 i 开始长度为 2^j 的最小值 = min{从 i 开始长度为2^(j - 1) 的一段元素的最小值, 从i + 2^(j - 1) + 1开始长度为2^(j - 1)的最小值};

这个题在处理时同样可以借鉴这种思路,这个题在树上(我也不知道在说啥),所以:

以 f[i][j] 表示第i个结点的第2^j个祖先是哪个点,那么 f[i][0] 为第i个节点的父亲。

以 g[i][j] 表示第i个结点到 f[i][j](第i个结点的第2^j个祖先) 的最短距离,那么 g[i][0] 表示第i个节点到自己父亲的(最短)距离。

转移可以模仿ST算法:

f[i][j] = f[ f[i][j - 1] ][j - 1]; 第i个点的第2^j个祖先 = 【第i个点第2^(j - 1)的祖先】 的 【第2^(j - 1)的祖先】

g[i][j] = min(g[i][j - 1], g[ f[i][j - 1] ][j - 1]); 第i个结点到 自己的第2^j个祖先 的最短距离 = min{第i个结点到 自己的第 2^(j - 1) 个祖先 的最短距离,【 第i个结点的第2^(j - 1)个祖先】到 【自己的第2^(j - 1)个祖先】 的最短距离}

【】只是为了帮助断句。。。

之后若要查询(x, y)的最短距离只需查询 min{(x, pos)的最短距离,(y, pos)的最短距离} pos为x,y的最近公共祖先

那么借用dfs的思路即可预处理整张图得到f和g

 #include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
using namespace std;
struct node {
int x, y, val;
}edge[];
int n, m, cnt;
bool cmp(node a, node b) { return a.val > b.val; }
int u[], v[], next[], first[], w[];
int in[], father[], hi[];
void addedge(int st, int end, int value)
{
u[++cnt] = st, v[cnt] = end, w[cnt] = value;
next[cnt] = first[st];
first[st] = cnt;
}
int getfather(int x) { return father[x] == x ? x : father[x] = getfather(father[x]); }
void kruskal()
{
int count;
for (int i = ; i <= n; i++) father[i] = i;
for (int i = ; i <= m; i++) {
int st = edge[i].x, end = edge[i].y;
int fa = getfather(father[st]), fb = getfather(father[end]);
if (fa != fb) {
addedge(st, end, edge[i].val);
addedge(end, st, edge[i].val);
father[fb] = fa;
count++;
if (count == n - ) return;
}
}
}
int vis[];
int fa[][], Min[][];
void dfs(int o)
{
vis[o] = ;
for (int i = ; i <= ; i++) {
if (hi[o] < ( << i)) break;
fa[o][i] = fa[fa[o][i - ]][i - ];
Min[o][i] = min(Min[o][i - ], Min[fa[o][i - ]][i - ]);
}
for (int i = first[o]; i; i = next[i]) {
int end = v[i];
if (!vis[end]) {
fa[end][] = o;
Min[end][] = w[i];
hi[end] = hi[o] + ;
dfs(end);
}
}
}
int lca(int l, int r)
{
if (hi[l] < hi[r]) swap(l, r);
int t = hi[l] - hi[r];
for (int i = ; i <= ; i++) {
if (( << i) & t) l = fa[l][i];
}
for (int i = ; i >= ; i--) {
if (fa[l][i] != fa[r][i]) {
l = fa[l][i], r = fa[r][i];
}
}
if (l == r) return l;
return fa[l][];
}
int ask(int l, int r)
{
int ret = 0x3f3f3f3f;
int t = hi[l] - hi[r];
for (int i = ; i <= ; i++) {
if (t & ( << i)) {
ret = min(ret, Min[l][i]);
l = fa[l][i];
}
}
return ret;
}
int main()
{
memset(Min, 0x3f3f3f3f, sizeof(Min));
scanf("%d%d", &n, &m);
for (int i = ; i <= m; i++) {
scanf("%d%d%d", &edge[i].x, &edge[i].y, &edge[i].val);
}
sort(edge + , edge + + m, cmp);
kruskal();
for (int i = ; i <= n; i++) if (!vis[i]) dfs(i);
int t, l, r;
scanf("%d", &t);
while (t--) {
scanf("%d%d", &l, &r);
if (getfather(father[l]) != getfather(father[r])) printf("-1\n");
else {
int pos = lca(l, r);
printf("%d\n", min(ask(l, pos), ask(r, pos)));
}
}
return ;
}

变量名不好起啊。

 

[noip2013]货车运输(kruskal + 树上倍增)的更多相关文章

  1. NOIP2013 货车运输(最大生成树,倍增)

    NOIP2013 货车运输(最大生成树,倍增) A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道 ...

  2. [Luogu 1967] NOIP2013 货车运输

    [Luogu 1967] NOIP2013 货车运输 一年多前令我十分头大的老题终于可以随手切掉了- 然而我这码风又变毒瘤了,我也很绝望. 看着一年前不带类不加空格不空行的清纯码风啊,时光也好像回去了 ...

  3. NOIP2013 货车运输 (最大生成树+树上倍增LCA)

    死磕一道题,中间发现倍增还是掌握的不熟 ,而且深刻理解:SB错误毁一生,憋了近2个小时才调对,不过还好一遍AC省了更多的事,不然我一定会疯掉的... 3287 货车运输 2013年NOIP全国联赛提高 ...

  4. Luogu1967 NOIP2013 货车运输 最大生成树、倍增

    传送门 题意:给出一个$N$个节点.$M$条边的图,$Q$次询问,每一次询问两个点之间的所有可行路径中经过的边的边权的最小值中的最大值.$N \leq 10000 , M \leq 50000 , Q ...

  5. NOIp2013 货车运输 By cellur925

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

  6. NOIP2013 货车运输

    3.货车运输 (truck.cpp/c/pas) [问题描述] A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货 ...

  7. Luogu P1967 货车运输(Kruskal重构树)

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

  8. Codevs3278[NOIP2013]货车运输

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

  9. 【洛谷P1967】[NOIP2013]货车运输

    货车运输 题目链接 显然,从一点走到另一点的路径中,最小值最大的路径一定在它的最大生成树上 所以要先求出最大生成树,再在生成树上找最近公共祖先,同时求出最小值. #include<iostrea ...

随机推荐

  1. Landsat TM DN值转为表观反射率

    日地距离计算参见<中华人民共和国气象行业标准太阳能资源评估方法>  

  2. 转:透析QTP自动化测试框架SAFFRON

    1.为什么要使用框架? 框架是一组自动化测试的规范.测试脚本的基础代码,以及测试思想.惯例的集合.可用于减少冗余代码.提高代码生产率.提高代码重用性和可维护性.例如QTestWare就是QTP自动化测 ...

  3. hb_gui配置heartbeat做MariaDB的高可用

    系统平台:CentOS release 6.5 (Final) Kernel:2.6.32-431.el6.x86_64 一.启动hb_gui hb_gui & 添加资源组 添加MySQL_I ...

  4. Mybatis学习(5)高级映射

    需求: 一.一对一查询 查询订单信息,关联查询创建订单的用户信息: orders--->user:一个订单只由一个用户创建,一对一 orders表 和 user表: 1)使用resultType ...

  5. MapReduce入门例子

    计算文档中不同单词的个数. hello you hello me 步骤如下:

  6. memcached添加IP白名单,只允许指定服务器调用

    由于memcached默认安装是不用配置密码的(具体的密码配置我也没怎么研究,据说是有的,大家感兴趣去找一找) 然而memcached链接也是非常简单的 linux命令链接使用  Telnet IP地 ...

  7. JAVA字符串编码转换常用类

    无论是对程序的本地化还是国际化,都会涉及到字符编码的转换的问题.尤其在web应用中常常需要处理中文字符,这时就需要进行字符串的编码转换,将字符串编码转换为GBK或者GB2312.一.关键技术点:    ...

  8. php登录

    if ($name && $passowrd){ $sql = "SELECT * FROM liuyanban WHERE name = '$name' and passw ...

  9. LaTeX 多个图片共用一个题注的实现--子图形

    http://blog.sina.com.cn/s/blog_58b8951801000a9e.html \begin{figure}\centering\subfigure[这是第一幅图]{\lab ...

  10. Application Fundamentals

    Application Fundamentals 署名:译言biAji 链接:http://developer.android.com/guide/topics/fundamentals.html 应 ...