#include using namespace std; const int N = 110; const int INF = 0x3f3f3f3f; /* 个数  空间至少5  体积  价值 求: 最小价值 3 5 1 2 4 9 3 6 答案应该是:11。 即 1,4-->2+9=11 */ int n, m; int f[N]; int main() { scanf("%d %d", &n, &m); memset(f, 0x3f, sizeof f); f[0] = 0; // 01背包!!! for (int i = 1; i <= n; i++) { int v, w; scanf("%d %d", &v, &w); for (int j = m; j >= v; j--) f[j] = min(f[j], f[max(0, j - v)] + w); } printf("%d\n", f[m]); return 0; }