Cod sursa(job #1002535)

Utilizator Alexa2001Alexa Tudose Alexa2001 Data 28 septembrie 2013 08:26:13
Problema Problema rucsacului Scor 80
Compilator cpp Status done
Runda Arhiva educationala Marime 0.63 kb
#include <fstream>
#include <algorithm>

using namespace std;
ifstream f("rucsac.in");
ofstream g("rucsac.out");
int j,i,gmax,gg,n,p,Max;
long long a[10003];
int main()
{
    f>>n>>gmax>>gg>>p;
    if(gg<=gmax) {a[gg]=p;Max=gg;} else  Max=-1;

    for(j=1;j<n;++j)
    {f>>gg>>p;
    for(i=Max;i>=0;--i)
    if(a[i]>0 && i+gg<=gmax)
    {if(a[i+gg]==0) {a[i+gg]=a[i]+p;Max=max(i+gg,Max);}
    else if(a[i+gg]<a[i]+p) {a[i+gg]=a[i]+p;Max=max(i+gg,Max);}}

    if( a[gg]==0) a[gg]=p;
    else if(a[gg]<p) a[gg]=p;

    }
    Max=0;
    for(i=0;i<=gmax;++i) if(Max<a[i]) Max=a[i];
    g<<Max<<'\n';



    return 0;
}