30142023-02-08 11:34:371478Szörnyekcpp17Hibás válasz 0/1001.1s7268 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
1Elfogadva3ms1684 KiB
2Elfogadva3ms1932 KiB
subtask20/13
3Elfogadva3ms1936 KiB
4Hibás válasz3ms2056 KiB
5Hibás válasz3ms2260 KiB
6Hibás válasz3ms2484 KiB
subtask30/22
7Hibás válasz3ms2688 KiB
8Hibás válasz3ms2904 KiB
9Hibás válasz3ms3036 KiB
10Hibás válasz3ms2992 KiB
11Hibás válasz3ms3116 KiB
12Hibás válasz3ms3240 KiB
13Hibás válasz3ms3368 KiB
14Hibás válasz3ms3452 KiB
subtask40/65
15Időlimit túllépés1.1s4400 KiB
16Hibás válasz310ms6656 KiB
17Időlimit túllépés1.08s4756 KiB
18Hibás válasz83ms6744 KiB
19Hibás válasz82ms6744 KiB
20Hibás válasz83ms7056 KiB
21Hibás válasz82ms6944 KiB
22Hibás válasz82ms7268 KiB
23Hibás válasz81ms7160 KiB
24Hibás válasz81ms7160 KiB