Cod sursa(job #2025416)

Utilizator PondorastiAlex Turcanu Pondorasti Data 22 septembrie 2017 18:05:33
Problema Energii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.73 kb
#include <fstream>
#include <iostream>
#include <algorithm>
using namespace std;
const int NMAX = 5000, INF = 2e9;
int n, w, c[NMAX + 2], p[NMAX + 2], dp[NMAX + 2], i, j, maxi;
int main() {
    ifstream cin("energii.in");
    ofstream cout("energii.out");
    cin >> n >> w;
    for(i = 1; i <= n; ++i)
        cin >> p[i] >> c[i];
    for(j = 1; j <= w; j++)
        dp[j] = INF;
    for(i = 1; i <= n; ++i) {
        for(j = w; j >= 0; --j) {
            if(j + p[i] > w)
                dp[w] = min(dp[w], dp[j] + c[i]);
            else
                dp[j + p[i]] = min(dp[j + p[i]], dp[j] + c[i]);
            
            
        }
    }
    if(dp[w] == INF)
        cout << "-1\n";
    else
        cout << dp[w] << "\n";
    return 0;
}