题号:NC50537
时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
空间限制:C/C++/Rust/Pascal 32 M,其他语言64 M
64bit IO Format: %lld
题目描述
有N个任务排成一个序列在一台机器上等待执行,它们的顺序不得改变。机器会把这N个任务分成若干批,每一批包含连续的若干个任务。从时刻0开始,任务被分批加工,执行第i个任务所需的时间是

。另外,在每批任务开始前,机器需要S的启动时间,故执行一批任务所需的时间是启动时间S加上每个任务所需时间之和。
一个任务执行后,将在机器中稍作等待,直至该批任务全部执行完毕。也就是说,同一批任务将在同一时刻完成。每个任务的费用是它的完成时刻乘以一个费用系数

。
请为机器规划一个分组方案,使得总费用最小。
输入描述:
第一行是N。第二行是S。
下面N行每行有一对正整数,分别为
和
,表示第i个任务单独完成所需的时间是
及其费用系数
。
输出描述:
一个数,最小的总费用。
示例1
说明
分组方案为{1,2 }, {3 }, {4,5 },则完成时间为{5,5,10,14,14 },费用C= {15,10,30,42,56 },总费用为153。
备注:
对于全部数据,
。