P6573 [BalticOI 2017] Toll

题目背景

作为一个合格的货运公司,在送达货物的同时也要让花的钱最少。

题目描述

这座城市有 $n$ 个地点,这 $n$ 个地点之间有 $m$ 条边。 货运公司接到了 $o$ 个订单,他们要想方设法的让路途中花的钱最少。 对于每条路,都有三个信息: - $a,b$ 代表从 $a$ 连到 $b$; - $t$ 代表这条路需要多少钱。 并且对于每个订单,都给出 $a$ 和 $b$ 代表要把物品从 $a$ 运到 $b$ ,求每个订单需要花的最少的钱;如果无法送达就输出 $-1$。 特别的,对于两个编号为 $a,b$ 的路,一定满足: $$\left\lfloor\dfrac{b}{k}\right\rfloor=1+\left\lfloor\dfrac{a}{k}\right\rfloor$$ ($k$ 是一个给定的常数)。

输入格式

第一行四个整数 $k,n,m,o$ 代表一个常数,地点的个数,边的个数,订单的个数。 点的编号为从 $0$ 到 $n - 1$。 接下来 $m$ 行每行三个整数 $a,b,t$ 代表从 $a$ 连向 $b$ 要花费 $t$,保证满足 $\left\lfloor\dfrac{b}{k}\right\rfloor=1+\left\lfloor\dfrac{a}{k}\right\rfloor$,并且两点之间连接的边数不超过 $1$ 条边。 接下来 $o$ 行每行两个整数 $a,b$ 代表要从 $a$ 运货到 $b$。

输出格式

对于每个订单,输出一行一个整数表示答案。

说明/提示

#### 数据规模与约定 **本题采用捆绑测试。** - Subtask 1(7 pts):$k=1$。 - Subtask 2(10 pts):每个订单中的 $a=0$。 - Subtask 3(8 pts):$o \le 100$。 - Subtask 4(31 pts):$o \le 3000$。 - Subtask 5(44 pts):无特殊限制。 对于 $100\%$ 的数据,$1 \le n \le 50000$,$1 \le o \le 10000$,$1 \le k \le 5$,$0 \le a < b < n$,$1 \le t \le 10000$。 #### 说明 **翻译自 [BOI 2017 D1](https://boi.cses.fi/files/boi2017_day1.pdf) T3 Toll。** 翻译者:@[一只书虫仔](https://www.luogu.com.cn/user/114914)。 **本题强制 $O2$ 优化。**