Cod sursa(job #2976128)

Utilizator SennyUrsu Arsenie Senny Data 8 februarie 2023 13:06:49
Problema Problema rucsacului Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.13 kb
#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;
}