Cod sursa(job #586924)
Utilizator | Data | 3 mai 2011 13:59:35 | |
---|---|---|---|
Problema | Energii | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.56 kb |
#include <fstream>
using namespace std;
int d[1025][1025],c[1025],e[1025],n,total,i,j;
int main()
{
ifstream f("energii.in");
ofstream g("energii.out");
f>>n>>total;
for(int i=1;i<=n;i++)
{
f>>c[i]>>e[i];
}
for(i=1;i<=n;i++)
for(j=1;j<=total;j++)
{
if(c[i]>j) d[i][j]=d[i-1][j];
else
{
if(d[i-1][j]<e[i]+d[i-1][j-c[i]])
d[i][j]=e[i]+d[i-1][j-c[i]];
else
d[i][j]=d[i-1][j];
}
}
g<<d[n][total];
f.close();
g.close();
return 0;
}