#B4428. [CSP-X2025 山东] 勇者斗恶龙

[CSP-X2025 山东] 勇者斗恶龙

题目描述

为了拯救世界,勇者们终于来到了恶龙面前。

现在有 nn 位勇者排成一列准备迎战恶龙,勇者们位置事先已经排好不能改变,第 ii 位勇者的初始能力值为 aia_i,且每提升 1 点能力值,需要花费 bib_i 的代价。

但是如果任意相邻的两位勇者能力值相同,他们之间就会产生冲突从而导致战力大幅下降。

你可以通过提升勇者的能力值,来确保队伍中任意相邻的两名勇者能力值都不相同,从而以完美的状态迎接恶龙。

你只需要计算并输出满足条件所花费的最小的总代价。

输入格式

第一行一个整数 nn,表示勇士的数量。

接下来 nn 行,每行两个数 ai,bia_i, b_i 分别表示第 ii 位勇士的初始能力值和每提升 1 点能力值需要花费的代价。

输出格式

一行一个整数表示答案。

3
1 5
1 2
2 3
4
3
1 10
1 100
1 20
30

提示

【样例 1 解释】

如果把第一个勇者能力值增加 11,三位勇者的能力值变成 (2,1,2)(2, 1, 2),花费代价 55

如果把第二个勇者能力值增加 22,三位勇者的能力值变为 (1,3,2)(1, 3, 2),花费代价 44

如果把第二个勇者能力值增加 11,第三个勇者的能力值增加 11,三位勇者的能力值变为 (1,2,3)(1, 2, 3),花费代价 55

因此最小花费的代价为 44,可以证明没有更小的代价能满足条件。

【样例 2 解释】

可以分别提升第一位和第三位勇士的能力值 1 点,最小总花费为 30。

【样例 3】

见选手目录下的 hero/ex_hero3.inhero/ex_hero3.ans

该样例满足数据范围中测试点第 9~10 的限制。

【样例 4】

见选手目录下的 hero/ex_hero4.inhero/ex_hero4.ans

该样例满足数据范围中测试点第 11~12 的限制。

【样例 5】

见选手目录下的 hero/ex_hero5.inhero/ex_hero5.ans

该样例满足数据范围中测试点第 13~20 的限制。

【数据范围】

::cute-table{tuack}

测试点 nn \le 1ai,bi1 \le a_i, b_i \le 特殊性质
141\sim 4 1010 1010
585\sim 8 100100
9109\sim 10 10510^5 ai=1a_i = 1
111211\sim 12 bi=1b_i = 1
132013\sim 20 2×1052 \times 10^5 10910^9