30132023-02-08 11:33:551478Szörnyekcpp17Futási hiba 0/1003ms4436 KiB
#include <bits/stdc++.h>

using namespace std;

struct Szorny{

    long long int elet, sebzes;

};

bool rendez(Szorny sz1, Szorny sz2){

    double x1 = double(sz1.sebzes) / double(sz1.elet);
    double x2 = double(sz2.sebzes) / double(sz2.elet);

    return (x1 >= x2);

}

bool rendez1(Szorny sz1, Szorny sz2){

    return (sz1.sebzes <= sz2.sebzes);

}

int main()
{
    ifstream cin("elod.txt");

    long long int n, p, sum = 0, index = 1, megoldas = 0;

    cin >> n >> p;

    vector<Szorny> sz(n + 1);

    for(long long int i = 1; i <= n; i++){
        cin >> sz[i].elet >> sz[i].sebzes;
        sum += sz[i].sebzes;
    }

    sort(sz.begin(), sz.end(), rendez);

    sz[1].elet -= p;


    if(sz[1].elet <= 0){
        index++;
        sum -= sz[1].sebzes;
    }

    while(index != n + 1){

        megoldas += ceil(sz[index].elet / p) * sum;


        sum -= sz[index].sebzes;

        index++;

    }

    cout << megoldas;


    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Futási hiba3ms1840 KiB
2Futási hiba3ms2116 KiB
subtask20/13
3Futási hiba3ms2312 KiB
4Futási hiba3ms2676 KiB
5Futási hiba3ms2700 KiB
6Futási hiba3ms2836 KiB
subtask30/22
7Futási hiba3ms3120 KiB
8Futási hiba3ms3148 KiB
9Futási hiba3ms3156 KiB
10Futási hiba3ms3340 KiB
11Futási hiba3ms3208 KiB
12Futási hiba3ms3488 KiB
13Futási hiba3ms3760 KiB
14Futási hiba3ms3768 KiB
subtask40/65
15Futási hiba3ms3820 KiB
16Futási hiba3ms3820 KiB
17Futási hiba3ms4068 KiB
18Futási hiba3ms4096 KiB
19Futási hiba3ms4124 KiB
20Futási hiba3ms4220 KiB
21Futási hiba3ms4436 KiB
22Futási hiba3ms4384 KiB
23Futási hiba3ms4388 KiB
24Futási hiba3ms4384 KiB