제출 #941206

#제출 시각아이디문제언어결과실행 시간메모리
941206peterandvoiLet's Win the Election (JOI22_ho_t3)C++17
100 / 100
7 ms2440 KiB
#include <bits/stdc++.h>

using namespace std;

#ifdef ngu
#include "debug.h"
#else
#define debug(...) 42
#endif

const int N = 505;

int n, k;
double dp[N][N];
pair<int, int> a[N];

double get(int mid) {
    for (int i = 0; i <= n; ++i) {
        for (int j = 0; j <= k - mid; ++j) {
            dp[i][j] = 1e9;
        }
    }
    dp[0][0] = 0;
    for (int i = 1; i <= n; ++i) {
        for (int j = 0; j <= min(i, k - mid); ++j) {
            int x = i - j - 1;
            if (j > 0) {
                dp[i][j] = min(dp[i][j], dp[i - 1][j - 1] + 1.0 * a[i].first / (mid + 1));
            }
            if (x >= mid || a[i].second != 1001) {
                dp[i][j] = min(dp[i][j], dp[i - 1][j] + (x < mid ? 1.0 * a[i].second / (x + 1) : 0));
            }
        }
    }
    return dp[n][k - mid];
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    #ifdef ngu
    freopen("test.inp", "r", stdin);
    freopen("test.out", "w", stdout);
    #endif
    cout << fixed << setprecision(15);
    cin >> n >> k;
    for (int i = 1; i <= n; ++i) {
        cin >> a[i].first >> a[i].second;
        a[i].second = a[i].second == -1 ? 1001 : a[i].second;
    }
    sort(a + 1, a + n + 1, [&](auto x, auto y) {
        return x.second < y.second;
    });
    int l = 1, r = n, res = 0;
    for (int i = 1; i <= n; ++i) {
        r -= a[i].second == 1001;
    }
    r = min(r, k);
    while (l <= r) {
        int mid = l + r >> 1;
        if (get(mid - 1) >= get(mid)) {
            res = mid;
            l = mid + 1;
        } else {
            r = mid - 1;
        }
    }
    cout << get(res);
}

컴파일 시 표준 에러 (stderr) 메시지

Main.cpp: In function 'int main()':
Main.cpp:60:21: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   60 |         int mid = l + r >> 1;
      |                   ~~^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...