3124: GESP7级2312 商品交易
内存限制:256 MB
时间限制:1.000 S
评测方式:文本比较
命题人:
提交:13
解决:7
题目描述
市场上共有 种商品,编号从 至 ,其中,第 种商品价值 元。
现在共有 个商人,编号从 至 。在第 个商人这,你可以使用你手上的第 种商品交换商人手上的第 种商品。每个商人都会按照商品价值进行交易,具体来说,如果 ,他将会付给你 元钱;否则,那么你需要付给商人 元钱。除此之外,每次交易商人还会收取 元作为手续费,不论交易商品的价值孰高孰低。
你现在拥有商品 ,并希望通过一些交换来获得商品 。请问你至少要花费多少钱?(当然,这个最小花费也可能是负数,这表示你可以在完成目标的同时赚取一些钱。)
输入
第一行四个整数 ,分别表示商品的数量、商人的数量、你持有的商品以及你希望获得的商品。保证 ,保证 。
第二行 个用单个空格隔开的正整数 ,依次表示每种商品的价值。保证 。
接下来 行,每行两个整数 ,表示在第 个商人这,你可以使用第 种商品交换第 种商品。保证 ,保证 。
输出
输出一行一个整数,表示最少的花费。特别地,如果无法通过交换换取商品 ,请输出
No solution。样例输入 复制
3 5 0 2
1 2 4
1 0
2 0
0 1
2 1
1 2
样例输出 复制
5
提示
在常规程序中,输入、输出时提供提示是好习惯。但在本场考试中,由于系统限定,请不要在输入、输出中附带任何提示信息。
**样例解释 1**
可以先找2 号商人,花2-1=1 元的差价以及1 元手续费换得商品1 ,再找4 号商人,花4-2 元的差价以及1元手续费换得商品2 。总计花费1+1+2+1=5 元。
**样例解释 2**
可以找2 号商人,直接换得商品2 的同时,赚取100-4=96 元差价,再支付1 元手续费,净赚95 元。
也可以先找0 号商人换取商品1 ,再找1 号商人换取商品2 ,不过这样只能赚94 元。
**数据规模**
对于30%的测试点,保证N<=10 ,M<=20 。
对于70%的测试点,保证N<=10^3^ ,M<=10^4^ 。
对于100%的测试点,保证 N<=10^5^,M<=2*10^5^