#741. Sắp xếp nhiệm vụ 3 (ARRANGE)

Bộ nhớ: 512 MiB Thời gian: 1000 ms Nhập/xuất từ luồng chuẩn
Kiểu bài: Thông thường Kiểu chấm: So sánh văn bản
Đưa lên bởi: Trùm CUỐI

Đề bài

N nhiệm vụ được sắp xếp thành một dãy chờ thực hiện trên một máy, thứ tự của chúng không được thay đổi. Máy sẽ chia N nhiệm vụ này thành một số lô, mỗi lô bao gồm các nhiệm vụ liên tiếp nhau. Bắt đầu từ thời điểm 0 , các nhiệm vụ được gia công theo từng lô. Thời gian cần thiết để thực hiện nhiệm vụ thứ i T_i . Ngoài ra, trước khi bắt đầu mỗi lô nhiệm vụ, máy cần thời gian khởi động là S . Do đó, thời gian cần thiết để thực hiện một lô nhiệm vụ là thời gian khởi động S cộng với tổng thời gian thực hiện của từng nhiệm vụ trong lô đó.

Sau khi một nhiệm vụ được thực hiện xong, nó sẽ chờ trong máy cho đến khi toàn bộ nhiệm vụ trong cùng lô đó hoàn thành. Nghĩa là, các nhiệm vụ trong cùng một lô sẽ hoàn thành tại cùng một thời điểm. Chi phí của mỗi nhiệm vụ được tính bằng thời điểm hoàn thành của nó nhân với một hệ số chi phí C_i .

Hãy lập kế hoạch phân nhóm cho máy sao cho tổng chi phí là nhỏ nhất.

Dữ liệu:

  • Dòng đầu tiên chứa hai số nguyên, lần lượt là N, S .
  • N dòng tiếp theo, mỗi dòng chứa hai số nguyên T_i, C_i .

Kết quả:

  • Một số duy nhất là tổng chi phí nhỏ nhất.

Ví dụ:

Dữ liệu:

5
1
1 3
3 2
4 3
2 3
1 4

Kết quả:

153

Giới hạn: 1\le N\le 3\times 10^5, 1\le S\le 2^8, |T_i|\le 2^8, 0\le C_i\le 2^8 .

  • Lưu ý rằng mặc dù T_i biểu thị thời gian, nhưng trong bài toán này T_i có thể là số âm.