Pagini recente » Cod sursa (job #2669525) | Cod sursa (job #1997561) | Cod sursa (job #27707) | Cod sursa (job #712704) | Cod sursa (job #2976128)
#include<bits/stdc++.h>
using namespace std;
struct obiect{
int greutate, valoare;
double parte;
}obiecte[1005];
void sortare(obiect a[], int n){
for (int i = 0; i < n; i++){
for (int j = i + 1; j < n; j++)
if (a[i].parte > a[j].parte)
swap(a[i], a[j]);
}
}
int main(){
ios_base::sync_with_stdio(0);
cin.tie(0);
freopen("rucsac.in", "r", stdin);
freopen("rucsac.out", "w", stdout);
int n, gmax;
cin >> n >> gmax;
int i;
for (i = 0; i < n; i++){
cin >> obiecte[i].greutate >> obiecte[i].valoare;
obiecte[i].parte = (double) obiecte[i].valoare / obiecte[i].greutate;
}
sortare(obiecte, n);
int g = gmax, maxbani = 0;
double rs = 0;
for (int i = 0; i <= n; i++){
maxbani += obiecte[i].valoare;
}
int k = 0;
n-=1;
while(g != 0 && k <= n){
if (g - obiecte[n - k].greutate >= 0){
g-=obiecte[n - k].greutate;
rs += obiecte[n - k].valoare;
k+=1;
}else{
rs += obiecte[n - k].parte * g;
g = 0;
}
}
cout << (int) rs;
return 0;
}