A95975.[GESP202312 七级] 商品交易

普及/提高-

GESP

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

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

输入格式

第一行四个整数 N,M,a,bN,M,a,b,分别表示商品的数量、商人的数量、你持有的商品以及你希望获得的商品。保证 0a,b<N0 ≤ a, b < N、保证 aabb
第二行 NN 个用单个空格隔开的正整数 v0,v1,...,vN1v_0, v_1, ... , v_{N-1},依次表示每种商品的价值。保证 1vi<1091 ≤ vi < 10^9
接下来 MM 行,每行两个整数 xj,yjx_j , y_j,表示第 jj 个商人愿意使用第 xjx_j 种商品交换第 yjy_j 种商品。保证 0xjyj<N0 ≤ x_j ,y_j < N 保证 xjx_jyjy_j

输出格式

输出一行一个整数,表示最少的花费。特别地,如果无法通过交换换取商品 ,请输出 No solutionNo\ 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

说明/提示

在常规程序中,输入、输出时提供提示是好习惯。但在本场考试中,由于系统限定,请不要在输入、输出中附带任何提示信息。

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

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

数据规模
对于 30%30\% 的测试点,保证 N10M20N ≤ 10,M ≤ 20
对于 70%70\% 的测试点,保证 N103M104N ≤ 10^3,M ≤ 10^4
对于 100%100\% 的测试点,保证 N105M2x105N ≤10^5,M ≤ 2 x 10^5

首页