Pagini recente » Cod sursa (job #2457480) | Cod sursa (job #2817621) | Cod sursa (job #2475158) | Cod sursa (job #1346817) | Cod sursa (job #1853236)
#include <fstream>
#define mini(a, b) ( (a)<(b) ? (a) : (b) )
using namespace std;
ifstream cin ("energii.in");
ofstream cout ("energii.out");
const int MAX = 5e4 + 5, LIM = 1e4 + 5, INF = 1e4 + 1;
int n, caut, val, g, v[MAX], rez = MAX;
int main()
{
cin>>n>>caut;
for(int i=1; i<=MAX; ++i)
v[i] = INF;
v[0] = 0;
for(int i=1; i<=n; ++i)
{
cin>>g>>val;
for(int j=LIM - g; j>=0; --j)
if(v[j] != INF and v[j+g] > v[j] + val){
v[j+g] = v[j] + val;
if(v[j+g] >= caut){
rez = mini(rez, v[j+g]);
}
}
}
cout<<rez;
return 0;
}