Pagini recente » Cod sursa (job #1890061) | Cod sursa (job #948498) | Cod sursa (job #240481) | Cod sursa (job #972197) | Cod sursa (job #1002535)
#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;
}