55142023-07-04 19:39:13AndrosGladiátorok (40 pont)cpp17Időlimit túllépés 22/40899ms11092 KiB
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#define ll long long
using namespace std;

//Magyarazattal

int main()
{
	ios_base::sync_with_stdio(true);
	cin.tie(0);
	//Hiba=>Mindenhol long long
	ll szendb, caedb;
	cin >> szendb >> caedb;
	//Beolvasas, a szenatorok parokba lesznek beolvasva.
	vector<pair<ll, ll>> szenator(szendb);
	for (ll i = 0; i < szendb; i++)
	{
		cin>>szenator[i].first >> szenator[i].second;
	}
	
	vector<ll> caesar(caedb);

	for (ll i = 0; i < caedb; i++)
	{
		cin>>caesar[i];
	}

	//A szortirozas az elso par szerll szortiroz.
	//A legjobb ha a leggyengebbek lesznek elol.
	sort(szenator.begin(), szenator.end());

	vector<ll> hozott_ero(szendb);//az ero, amit az eddig legyozott gladiatorokbol szerzunk.
	ll sum = 0;
	for (ll i = 0; i < szendb; i++)
	{
		hozott_ero[i] = sum;
		sum += szenator[i].second;
	}

	vector<ll> kello_ero(szendb);//Az ero ami az elejetol kell, hogy legyozzuk
	for (ll i = 0; i < szendb; i++)
	{
		kello_ero[i] = szenator[i].first - hozott_ero[i];
	}

	string out = "";

	for (ll glad : caesar)
	{	
		ll mego = -1;
		for (int i = 0; i < szendb; i++)
		{
			//Az elso olyan, ami nagyobb nala, ott veszit.
			//Kiirjuk meddig jutott.
			if (glad < kello_ero[i]) {
				mego = i;
				break;
			}
		}
		if (mego == -1) {
			out += to_string(szendb);
		}
		else {
			out+=to_string(mego);
		}
		out += " ";
	}
	cout << out;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base22/40
1Elfogadva0/03ms1684 KiB
2Elfogadva0/025ms4312 KiB
3Elfogadva2/23ms1944 KiB
4Elfogadva2/23ms2072 KiB
5Elfogadva2/24ms2520 KiB
6Elfogadva2/26ms2736 KiB
7Elfogadva2/24ms2972 KiB
8Elfogadva2/26ms3180 KiB
9Elfogadva2/26ms3380 KiB
10Elfogadva2/26ms3472 KiB
11Elfogadva2/230ms4604 KiB
12Elfogadva2/2150ms11092 KiB
13Elfogadva2/2131ms9292 KiB
14Időlimit túllépés0/2875ms7640 KiB
15Időlimit túllépés0/2865ms7508 KiB
16Időlimit túllépés0/2856ms7432 KiB
17Időlimit túllépés0/2848ms7384 KiB
18Időlimit túllépés0/2857ms7180 KiB
19Időlimit túllépés0/2875ms7464 KiB
20Időlimit túllépés0/2899ms7584 KiB
21Időlimit túllépés0/2874ms8144 KiB
22Időlimit túllépés0/2857ms7836 KiB