Pagini recente » Cod sursa (job #2532525) | Cod sursa (job #1598597) | Cod sursa (job #2617958) | Cod sursa (job #2142650) | Cod sursa (job #2980716)
#include <fstream>
using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
struct sdt
{
int gr,pr;
}a[5003];
int s[10003];
int main()
{
int n,g,gmax;
in>>n>>g;
for(int i=1;i<=n;i++)
{
in>>a[i].gr>>a[i].pr;
}
if(a[1].gr<=g)
{
gmax=a[1].gr;
s[gmax]=a[1].pr;
}
else
gmax=0;
for(int i=2;i<=n;i++)
{
for(int j=gmax;j>=1;j--)
{
if(s[j]!=0)
if(j+a[i].gr<=g)
s[j+a[i].gr]=max(s[j+a[i].gr],s[j]+a[i].pr);
}
s[a[i].gr]=max(s[a[i].gr],a[i].pr);
if(gmax+a[i].gr<=g)
{
gmax+=a[i].gr;
}
else gmax=g;
}
int maxi=0;
for(int i=1;i<=g;i++)
maxi=max(maxi,s[i]);
out<<maxi;
return 0;
}