Problem hidden
|This problem was hidden by Editorial Board member probably because it has incorrect language|version or invalid test data, or description of the problem is not clear.|

KNAPSACKHVT - Cái túi của thằng trộm

Một tên trộm lọt được vào một gia đình. Hắn mang theo một cái túi có thể tích M để đựng đồ ăn trộm. Trong nhà có n vật dụng (n ≤ 100), vật thứ i có thể tích là Vi ≤ 100 và giá trị là Pi ≤ 100. Vậy tên trộm phải chọn những vật nào để lấy đi mà tổng giá trị của các vật đó là lớn nhất.

Input: 

  • Dòng 1: Chứa hai số n, M cách nhau một dấu cách
  • N dòng tiếp theo mỗi dòng i ghi hai số Vi và Pi cách nhau một dấu cách

Output: 

  • Dòng 1: Ghi tổng giá trị lớn nhất mà tên trộm có thể lấy được
  • Dòng 2: Ghi chỉ số những vật dụng bị lấy đi

Ví dụ

Example

Input:
5 11
3 3
4 4
5 4
9 10
4 4
Output:
11
5 2 1 

Được gửi lên bởi:Vương Trung Hiếu Nghĩa
Ngày:2016-01-31
Thời gian chạy:1s
Giới hạn mã nguồn:50000B
Memory limit:1536MB
Cluster: Cube (Intel G860)
Ngôn ngữ cho phép:C++ 4.3.2 CPP CPP14 PAS-GPC PAS-FPC

© Spoj.com. All Rights Reserved. Spoj uses Sphere Engine™ © by Sphere Research Labs.