Pagini recente » Cod sursa (job #1804209) | Cod sursa (job #872706) | Cod sursa (job #1595222) | Cod sursa (job #1377160) | Cod sursa (job #2534231)
#include <fstream>
#include <bitset>
using namespace std;
int D[10010];
int n,m,G,g,i,j,p,sol;
bitset<10010> V;
int main()
{
ifstream fin ("rucsac.in");
ofstream fout("rucsac.out");
fin>>n>>G;
V[0]=1;
m=1;
for(i=1;i<=n;i++)
{
fin>>g>>p;
m=m+g;
if(m>G)
m=G;
for(j=m;j>=0;j--)
{
if(V[j]==1)
{
if(j+g<=G&&D[j+g]<D[j]+p)
{
V[j+g]=1;
D[j+g]=D[j]+p;
sol=max(sol,D[j+g]);
}
}
}
}
fout<<sol;
return 0;
}