30172023-02-08 11:53:571478Szörnyekcpp17Hibás válasz 0/100112ms7784 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 - sz1.elet >= sz2.sebzes - sz2.elet);

}

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() + 1, sz.end(), rendez1);


    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
1Elfogadva3ms1844 KiB
2Hibás válasz3ms2096 KiB
subtask20/13
3Hibás válasz3ms2212 KiB
4Hibás válasz2ms2304 KiB
5Hibás válasz3ms2428 KiB
6Hibás válasz3ms2788 KiB
subtask30/22
7Futási hiba3ms2912 KiB
8Hibás válasz3ms3140 KiB
9Futási hiba3ms3340 KiB
10Hibás válasz3ms3296 KiB
11Hibás válasz3ms3408 KiB
12Hibás válasz3ms3596 KiB
13Hibás válasz3ms3820 KiB
14Hibás válasz3ms3908 KiB
subtask40/65
15Futási hiba59ms7188 KiB
16Futási hiba52ms7324 KiB
17Futási hiba70ms7540 KiB
18Hibás válasz78ms7120 KiB
19Hibás válasz76ms7204 KiB
20Hibás válasz75ms7200 KiB
21Hibás válasz76ms7316 KiB
22Hibás válasz75ms7524 KiB
23Hibás válasz112ms7676 KiB
24Hibás válasz109ms7784 KiB