Submission #3767889


Source Code Expand

#include <algorithm>
#include <iostream>
#include <vector>
#include <math.h>
#include <set>
#include <map>
#include <string>
#include <stack>
#include <queue>
#include <iomanip>
#include <numeric>
#include <tuple>
#include <bitset>
#include <complex>
#include <unistd.h>
#include <cassert>
#include <cctype>
#include <random>
#define _USE_MATH_DEFINES
#define _GLIBCXX_DEBUG
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
typedef pair<ll, ll> plglg;
typedef pair<double, ll> pdlg;
typedef tuple<int, int, int> tiii;
typedef tuple<ll, ll, ll> tlglglg;
typedef tuple<double, double, double> tddd;
typedef complex<double> xy_t;
#define REP(i, x, y) for(ll i = x; i < y; i++)
int dx[4] = {1, 0, -1, 0};
int dy[4] = {0, 1, 0, -1};
double pi = 3.141592653589793;
ll mod = 1000000007;
int intmax = 2147483647;
int intmin = -2147483648;
ll llmax = 9223372036854775807;
ll llmin = -9223372036854775807;
int iinf = intmax / 8;
ll inf = llmax / 8;
double eps = 1e-11;

ll dp[5010][5010];

int main() {
    ll N;
    cin >> N;
    tiii T[N];
    REP(i, 0, N) {
        ll h, p;
        cin >> h >> p;
        T[i] = make_tuple(h + p, h, p);
    }
    sort(T, T + N);
    REP(i, 0, 5010) {
        fill(dp[i], dp[i] + 5010, inf);
    }
    dp[0][0] = 0;
    REP(i, 1, N + 1) {
        dp[i][0] = 0;
        REP(j, 1, i + 1) {
            dp[i][j] = dp[i - 1][j];
            if (get<1>(T[i - 1]) >= dp[i - 1][j - 1]) {
                dp[i][j] = min(dp[i][j], dp[i - 1][j - 1] + get<2>(T[i - 1]));
            }
        }
    }
    ll ans = 0;
    REP(i, 0, N + 2) {
        if (dp[N][i] == inf) {
            ans = i - 1;
            break;
        }
    }
    cout << ans << endl;
}

Submission Info

Submission Time
Task D - Zabuton
User NMLibrary
Language C++14 (GCC 5.4.1)
Score 700
Code Size 1772 Byte
Status AC
Exec Time 85 ms
Memory 196480 KB

Judge Result

Set Name sample All
Score / Max Score 0 / 0 700 / 700
Status
AC × 3
AC × 46
Set Name Test Cases
sample sample-01.txt, sample-02.txt, sample-03.txt
All sample-01.txt, sample-02.txt, sample-03.txt, 01-01.txt, 01-02.txt, 01-03.txt, 01-04.txt, 01-05.txt, 01-06.txt, 01-07.txt, 01-08.txt, 01-09.txt, 01-10.txt, 01-11.txt, 01-12.txt, 01-13.txt, 01-14.txt, 01-15.txt, 01-16.txt, 01-17.txt, 01-18.txt, 01-19.txt, 01-20.txt, 01-21.txt, 01-22.txt, 01-23.txt, 01-24.txt, 01-25.txt, 01-26.txt, 01-27.txt, 01-28.txt, 01-29.txt, 01-30.txt, 01-31.txt, 01-32.txt, 01-33.txt, 01-34.txt, 01-35.txt, 01-36.txt, 01-37.txt, 01-38.txt, 01-39.txt, 01-40.txt, sample-01.txt, sample-02.txt, sample-03.txt
Case Name Status Exec Time Memory
01-01.txt AC 62 ms 196352 KB
01-02.txt AC 62 ms 196352 KB
01-03.txt AC 64 ms 196352 KB
01-04.txt AC 68 ms 196352 KB
01-05.txt AC 80 ms 196352 KB
01-06.txt AC 81 ms 196352 KB
01-07.txt AC 80 ms 196352 KB
01-08.txt AC 81 ms 196352 KB
01-09.txt AC 80 ms 196352 KB
01-10.txt AC 62 ms 196352 KB
01-11.txt AC 63 ms 196352 KB
01-12.txt AC 70 ms 196352 KB
01-13.txt AC 80 ms 196352 KB
01-14.txt AC 81 ms 196352 KB
01-15.txt AC 81 ms 196352 KB
01-16.txt AC 81 ms 196352 KB
01-17.txt AC 80 ms 196352 KB
01-18.txt AC 81 ms 196352 KB
01-19.txt AC 62 ms 196480 KB
01-20.txt AC 64 ms 196352 KB
01-21.txt AC 73 ms 196352 KB
01-22.txt AC 83 ms 196352 KB
01-23.txt AC 84 ms 196352 KB
01-24.txt AC 83 ms 196352 KB
01-25.txt AC 83 ms 196352 KB
01-26.txt AC 83 ms 196352 KB
01-27.txt AC 84 ms 196352 KB
01-28.txt AC 80 ms 196352 KB
01-29.txt AC 80 ms 196352 KB
01-30.txt AC 81 ms 196352 KB
01-31.txt AC 80 ms 196352 KB
01-32.txt AC 80 ms 196352 KB
01-33.txt AC 81 ms 196352 KB
01-34.txt AC 81 ms 196352 KB
01-35.txt AC 85 ms 196352 KB
01-36.txt AC 85 ms 196352 KB
01-37.txt AC 84 ms 196352 KB
01-38.txt AC 84 ms 196352 KB
01-39.txt AC 84 ms 196352 KB
01-40.txt AC 81 ms 196352 KB
sample-01.txt AC 62 ms 196352 KB
sample-02.txt AC 63 ms 196352 KB
sample-03.txt AC 62 ms 196352 KB