#include #include #include #include #include #include #include #include #include #include #include #include #include #include constexpr int MAX_INT = 2147483647; constexpr int MIN_INT = -2147483648; #define rep(n, a, b) for (int (n) = (a); (n) < (b); (n)++) #define rrep(n, a, b) for (int (n) = (a); (n) >= (b); (n)--) #define llrep(n, a, b) for (long long (n) = (a); (n) < (b); (n)++) #define llrrep(n, a, b) for (long long (n) = (a); (n) >= (b); (n)--) #define itrAll(x) (x).begin(), (x).end() #define inputvec(v) for (auto& x : v) {std::cin >> x;} using namespace std; using uint = unsigned int; using ushort = unsigned short; using byte = unsigned char; using ll = long long; using ull = unsigned long long; using ldouble = long double; using ipair = pair; using llpair = pair; template void chmin(T& v1, T v2) { if (v1 > v2) v1 = v2; } template void chmax(T& v1, T v2) { if (v1 < v2) v1 = v2; } int main() { int N, W, D; cin >> N >> W>> D; int c0 = 0, c1 = 0; vector> wv0(N), wv1(N); rep(i, 0, N) { int ti; cin >> ti; if (!ti) { cin >> wv0[c0].first >> wv0[c0].second; c0++; } else { cin >> wv1[c1].first >> wv1[c1].second; c1++; } } wv0.resize(c0); wv1.resize(c1); vector> max0(c0 + 1, vector(5001)), max1(c1 + 1, vector(5001)); // [i][w] := i 番目までの中からいくつか選んで, 総重量を w にしたときの価値の最大値 rep(i, 0, c0) max0[i + 1][wv0[i].first] = wv0[i].second; rep(i, 0, c1) max1[i + 1][wv1[i].first] = wv1[i].second; // dp1 for (int i = 1; i <= c0; i++) { auto& wv = wv0[i - 1]; for (int w = 1; w <= W; w++) { int whenNotUsed = max0[i - 1][w]; int whenUsed = (w >= wv.first) ? max0[i - 1][w - wv.first] : 0; if (whenNotUsed) { if (whenUsed) chmax(max0[i][w], max(whenNotUsed, whenUsed + wv.second)); else chmax(max0[i][w], whenNotUsed); } else if (whenUsed) { chmax(max0[i][w], whenUsed + wv.second); } } } // dp2 for (int i = 1; i <= c1; i++) { auto& wv = wv1[i - 1]; for (int w = 1; w <= W; w++) { int whenNotUsed = max1[i - 1][w]; int whenUsed = (w >= wv.first) ? max1[i - 1][w - wv.first] : 0; if (whenNotUsed) { if (whenUsed) chmax(max1[i][w], max(whenNotUsed, whenUsed + wv.second)); else chmax(max1[i][w], whenNotUsed); } else if (whenUsed) { chmax(max1[i][w], whenUsed + wv.second); } } } int ans = 0; for (int d = 0; d <= D; d++) { chmax(ans, max(max0[c0][d], max1[c1][d])); for (int w0 = 1; (w0 << 1) + d <= W; w0++) { int m0 = max0[c0][w0]; int m1 = max1[c1][w0 + d]; if ((ll)m0 * m1) chmax(ans, m0 + m1); } for (int w1 = 1; (w1 << 1) + d <= W; w1++) { int m0 = max0[c0][w1 + d]; int m1 = max1[c1][w1]; if ((ll)m0 * m1) chmax(ans, m0 + m1);; } } cout << ans << endl; return 0; }