#aBC328G. [ABC328G] Cut and Reorder
[ABC328G] Cut and Reorder
AT_abc328_g [ABC328G] Cut and Reorder
题目描述
给定长度为 的数列 和 。
你可以对数列 进行如下两种操作,操作的顺序和次数均不限:
- 可以在任意位置将 分割,并将分割后的各段自由重新排列。每分割一次(即每增加一个分割点)需要花费 的代价。具体来说,花费 的代价,可以任选一个长度为 的分割点序列 $(i_0,i_1,i_2,\ldots,i_X)\ (0=i_0<i_1<i_2<\cdots<i_X=N)$ 和 的任意排列 ,然后将 $(A_{i_{p_j-1}+1},A_{i_{p_j-1}+2},\ldots,A_{i_{p_j}})$ 按照 的升序依次连接,得到新的 。
- 可以任选 的一个元素和一个整数 ,将该元素加上 ,花费 的代价。
请你通过若干次操作,使得最终 和 完全相同,求所需总代价的最小值。
输入格式
输入以如下格式从标准输入读入:
输出格式
请输出答案。
输入输出样例 #1
输入 #1
5 1
3 1 4 1 5
9 2 6 5 3
输出 #1
12
输入输出样例 #2
输入 #2
5 1000000000
3 1 4 1 5
9 2 6 5 3
输出 #2
15
输入输出样例 #3
输入 #3
22 467772225675200
814424018890229 837987908732596 281175505732576 405797525366223 319378664987871 305374284356649 519144936694626 316916938328237 590332737480143 506785561790072 945769796193819 365498597798550 5386616044591 672368930784037 478017750715806 340276460237787 176509793332130 2734777402752 677509027289850 250325127275409 260270543315523 103584313625431
720386673780641 77160494100361 540947273460639 255177791002759 969333325196025 477751866935037 369600749728569 466236682780196 343161112138696 541310338013515 42740499599240 165778332156355 618106559852784 16582487395877 591851763813728 221861304303645 982850624742022 728669467505250 337968530842725 746724490610504 61587851254728 451153536869240
输出 #3
4370668608634071
说明/提示
限制条件
- 输入均为整数
样例解释 1
例如,可以通过如下操作使 和 相等:
- 给 加上 ,花费 ,。
- 给 加上 ,花费 ,。
- 给 加上 ,花费 ,。
- 将 分割为 和 ,并交换顺序,花费 ,。
- 给 加上 ,花费 ,。
- 给 加上 ,花费 ,。
- 给 加上 ,花费 ,。
总代价为 。无法用 或更少的代价使 和 相等,因此输出 。
样例解释 2
例如,可以通过如下操作使 和 相等:
- 给 加上 ,花费 ,。
- 给 加上 ,花费 ,。
- 给 加上 ,花费 ,。
- 给 加上 ,花费 ,。
- 给 加上 ,花费 ,。
总代价为 。无法用 或更少的代价使 和 相等,因此输出 。
样例解释 3
输入和答案可能超出 整数范围。
由 ChatGPT 4.1 翻译