[GESP202312 七级] 商品交易

GESP编程共123题,本题是整站第1390题,已经有人完成了本题,加油!

题目描述

市场上共有 N 种商品,编号从 0 至 N−1 ,其中,第 i 种商品价值 vi​ 元。

现在共有 M 个商人,编号从 0 至 M−1 。在第 j 个商人这,你可以使用你手上的第 xj​ 种商品交换商人手上的第 yj​ 种商品。每个商人都会按照商品价值进行交易,具体来说,如果 vxj​​>vyj​​,他将会付给你 vxj​​−vyj​​元钱;否则,那么你需要付给商人 vxj​​−vyj​​ 元钱。除此之外,每次交易商人还会收取 1 元作为手续费,不论交易商品的价值孰高孰低。

你现在拥有商品 a ,并希望通过一些交换来获得商品 b 。请问你至少要花费多少钱?(当然,这个最小花费也可能是负数,这表示你可以在完成目标的同时赚取一些钱。)

输入格式

第一行四个整数 N,M,a,b,分别表示商品的数量、商人的数量、你持有的商品以及你希望获得的商品。保证 0≤a,b<N ,保证 a != b。

第二行 N 个用单个空格隔开的正整数 v0​,v1​,…,vN−1​ ,依次表示每种商品的价值。保证 1≤vi​≤10^9。

接下来 M 行,每行两个整数 xj​,yj​ ,表示在第 j 个商人这,你可以使用第 xj​ 种商品交换第 yj​ 种商品。保证 0≤xj​,yj​<N,保证 xj​ != yj​ 。

输出格式

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

输入输出样例

输入 #1

3 5 0 2
1 2 4
1 0
2 0
0 1
2 1
1 2

输出 #1

5

输入 #2

3 3 0 2
100 2 4
0 1
1 2
0 2

输出 #2

-95

输入 #3

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

输出 #3

No solution

说明/提示

数据范围

对于30%的测试点,保证 N≤10 ,M≤20。

对于70%的测试点,保证 N≤10^3 ,M≤10^4。

对于100%的测试点,保证 N≤10^5,M≤2×10^5。

别灰心,再试一次!

真题解析

【解题思路】发现不管通过什么方式换,最终因为价值不同而花费的金币数都是固定的,即v[b]-v[a],a为持有的商品,b为希望获得商品,唯一的区别是每次交易都要额外支付1块钱,所以需要最小化交易次数,我们把每件商品看作1个点,如果某件商品x能够换为某件商品y,则让x和y连一条边,我们的目标是从商品a出发尽快到达商品b,即经过的边的数量尽量少,可以通过bfs求经过的最少的边数,设这个值为min_dist[dst],那么最终答案为

min_dist[dst]+v[b]-v[a]。

【参考程序】

本站题目仅供学习,GESP版权归CCF所有,如有侵权请联系删除。站长陈老师QQ及微信:208234。