Cod sursa(job #2987183)

Utilizator MorarCezarMorar Cezar MorarCezar Data 2 martie 2023 08:46:26
Problema Energii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.82 kb
#include <bits/stdc++.h>

using namespace std;
ifstream f("energii.in");
ofstream g("energii.out");
int Gr,n;
int dp[10005];
struct cacat{
    int w,p;
}v[10005];
void citire()
{
    f>>n>>Gr;
    for(int i=1;i<=n;i++){
        f>>v[i].w>>v[i].p;
        //suma+=v[i].p;
}
}
void solve()
{
    for(int i=1;i<=Gr;i++)
        dp[i]=INT_MAX;
    int sol=INT_MAX;
    for(int i=1;i<=n;i++)
        for(int j=Gr;j>=0;j--)

            {
               if(dp[j]==INT_MAX)
                continue;
                if(j+v[i].w>=Gr)
                    sol=min(sol,dp[j]+v[i].p);
                else
                    dp[j+v[i].w]=min(dp[j+v[i].w],dp[j]+v[i].p);
            }
    if(sol==INT_MAX)
        g<<"-1";
    else
        g<<sol;
}
int main()
{
    citire();
    solve();
    return 0;
}