243862026-02-10 20:30:50KristófBányász RPG (40 pont)cpp17Hibás válasz 36/4064ms1092 KiB
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main()
{
    int n;
    cin>>n;
    vector<pair<int,int>> a(n);
    for(auto &x:a)cin>>x.first;
    for(auto &x:a)cin>>x.second;
    sort(a.begin(),a.end());
    int endi=n-1;
    int i=0;
    int ans=0;
    int level=0;
    while(i<=endi)
        {
        if(a[i].first<=level)
            {
            ans+=a[i].second;
            level+=a[i].second;

            i++;
            }
        else
            {
            int modosit=min(a[i].first-level,a[endi].second);
            ans+=modosit*2;
            level+=modosit;
            a[endi].second-=modosit;


            if(a[endi].second==0)
                endi--;
            }

        }
    cout<<ans;
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base36/40
1Elfogadva0/01ms316 KiB
2Elfogadva0/012ms316 KiB
3Elfogadva2/21ms316 KiB
4Elfogadva2/21ms316 KiB
5Elfogadva2/29ms316 KiB
6Elfogadva2/220ms744 KiB
7Elfogadva2/23ms508 KiB
8Elfogadva2/24ms500 KiB
9Elfogadva3/31ms324 KiB
10Elfogadva3/31ms508 KiB
11Elfogadva3/31ms508 KiB
12Elfogadva3/31ms316 KiB
13Elfogadva4/41ms316 KiB
14Elfogadva4/41ms316 KiB
15Hibás válasz0/237ms796 KiB
16Elfogadva2/248ms932 KiB
17Hibás válasz0/241ms820 KiB
18Elfogadva2/264ms1092 KiB