30042023-02-08 08:56:02samatSzörnyekcpp11Hibás válasz 0/100108ms7296 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
1Elfogadva3ms1816 KiB
2Hibás válasz3ms2180 KiB
subtask20/13
3Hibás válasz3ms2160 KiB
4Hibás válasz3ms2296 KiB
5Hibás válasz3ms2380 KiB
6Hibás válasz3ms2620 KiB
subtask30/22
7Hibás válasz3ms2848 KiB
8Hibás válasz3ms2944 KiB
9Hibás válasz2ms3024 KiB
10Hibás válasz3ms3156 KiB
11Hibás válasz3ms3236 KiB
12Hibás válasz3ms3244 KiB
13Hibás válasz2ms3240 KiB
14Hibás válasz3ms3480 KiB
subtask40/65
15Futási hiba61ms6780 KiB
16Futási hiba108ms6856 KiB
17Futási hiba70ms6916 KiB
18Hibás válasz85ms6968 KiB
19Hibás válasz85ms6928 KiB
20Hibás válasz83ms7004 KiB
21Hibás válasz85ms7256 KiB
22Hibás válasz85ms7216 KiB
23Hibás válasz82ms7296 KiB
24Hibás válasz82ms7200 KiB