#D. [GESP202312七级] 商品交易

    Type: Default 1000ms 256MiB

[GESP202312七级] 商品交易

You cannot submit for this problem because the contest is ended. You can click "Open in Problem Set" to view this problem in normal mode.

题目描述

市场上共有 NN 种商品,编号从 00N1N - 1 ,其中,第 ii 种商品价值 viv_{i} 元。 现在共有 MM 个商人,编号从 00M1M - 1 。在第 jj 个商人这,你可以使用第 xjx_{j} 种商品交换第 yjy_{j} 种商品。每个商人都会按照商品价值进行交易,具体来说,如果 vxj>vyjv_{x_{j}} > v_{y_{j}},他将会付给你 vyjvxjv_{y_{j}} - v_{x_{j}} 元钱;否则,那么你需要付给商人vxjvyjv_{x_{j}} - v_{y_{j}} 元钱。除此之外,每次交易商人还会收取 11 元作为手续费,不论交易商品的价值孰高孰低。 你现在拥有商品 aa ,并希望通过一些交换来获得商品 bb 。请问你至少要花费多少钱?(当然,这个最小花费也可能是负数,这表示你可以在完成目标的同时赚取一些钱。)

输入格式

第一行四个整数 N,M,a,bN, M, a, b ,分别表示商品的数量、商人的数量、你持有的商品以及你希望获得的商品。保证 0a,b<N0 \leq a, b < N,保证 aa 不等于 bb

第二行 NN 个用单个空格隔开的正整数 v0,v1,...,vN1v_{0}, v_{1}, ..., v_{N-1},依次表示每种商品的价值。保证 1vi1091 \leq v_{i} \leq 10^9

接下来 MM 行,每行两个整数 xi,yix_{i}, y_{i},表示第 ii 个商人愿意使用第 xix_{i} 种商品交换第 yiy_{i} 种商品。保证 0xi,yi<N0 \leq x_{i}, y_{i} < N ,保证 xix_{i} 不等于 yiy_{i}

输出格式

输出一行一个整数,表示最少的花费。特别地,如果无法通过交换换取商品 bb ,请输出 No solution

样例

3 5 0 2
1 2 4
1 0
2 0
0 1
2 1
1 2
5
3 3 0 2
100 2 4
0 1
1 2
0 2
-95

提示

样例 1 解释

可以先找 22 号商人,花 21=12 - 1 = 1 元的差价以及 11 元手续费换得商品 11 ,再找 44 号商人,花 424 - 2 元的差价以及 11 元手续费换得商品 22 。总计花费 1+1+2+1=51 + 1 + 2 + 1 = 5 元。

样例 2 解释

可以找 22 号商人,直接换得商品 22 的同时,赚取 1004=96100 - 4 = 96 元差价,再支付 11 元手续费,净赚 9595 元。 也可以先找 00 号商人换取商品 11 ,再找 11 号商人换取商品 22 ,不过这样只能赚 9494 元。

数据范围

对于 30%30 \% 的测试点,保证 N10M20N \leq 10 ,M \leq 20 。 对于 70%70 \% 的测试点,保证 N103M104N \leq 10^3 ,M \leq 10^4 。 对于 100%100 \% 的测试点,保证 N105M2105N \leq 10^5,M \leq 2*10^5

数据结构——图(最短路)

Not Claimed
Status
Done
Problem
4
Open Since
2025-3-29 17:30
Deadline
2025-4-6 23:59
Extension
24 hour(s)