#GESP7001. 商品交易

商品交易

题目背景

2023 年 12 月 GESP C++ 七级编程第 1 题

题目描述

市场上共有 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