Cod sursa(job #2302388)

Utilizator AndreiCroitoruAndrei Croitoru AndreiCroitoru Data 14 decembrie 2018 15:53:28
Problema Problema rucsacului Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.67 kb
#include <fstream>

using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
int d[5001],maxim[10001];
int main()
{
    int n,g,p,G,maxi=0;
    in>>n>>G;
    d[0]=1;
    for(int i=1; i<=n; i++)
    {
        in>>g>>p;
        for(int j=G; j>=0; j--)
        {
            if(d[j]==1)
            {
                if(d[j+g]==0)
                {
									maxim[j+g]=p;
                }
                else
								{
									if(p+maxim[j]>maxim[j+g])
										maxim[j+g]=p+maxim[j];
								}
            }

        }
    }
    for(int i=1;i<=n;i++)
		{
			if(maxim[i]>maxi)
				maxi=maxim[i];
		}
		out<<maxi;
    return 0;
}