5512 2023. 07. 04 19:33:58 Andros Gladiátorok (40 pont) cpp17 Időlimit túllépés 30/40 883ms 13680 KiB
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#define ll long long
using namespace std;

//Magyarazattal

int main()
{

	//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 Összpont Teszt Verdikt Idő Memória
base 30/40
1 Elfogadva 0/0 3ms 1680 KiB
2 Elfogadva 0/0 28ms 4448 KiB
3 Elfogadva 2/2 3ms 2096 KiB
4 Elfogadva 2/2 3ms 2188 KiB
5 Elfogadva 2/2 6ms 2624 KiB
6 Elfogadva 2/2 6ms 2836 KiB
7 Elfogadva 2/2 4ms 2948 KiB
8 Elfogadva 2/2 6ms 3172 KiB
9 Elfogadva 2/2 6ms 3400 KiB
10 Elfogadva 2/2 6ms 3492 KiB
11 Elfogadva 2/2 28ms 4672 KiB
12 Elfogadva 2/2 135ms 10944 KiB
13 Elfogadva 2/2 118ms 9336 KiB
14 Elfogadva 2/2 637ms 13596 KiB
15 Elfogadva 2/2 643ms 13680 KiB
16 Elfogadva 2/2 652ms 13652 KiB
17 Elfogadva 2/2 643ms 13612 KiB
18 Időlimit túllépés 0/2 883ms 7136 KiB
19 Időlimit túllépés 0/2 870ms 7256 KiB
20 Időlimit túllépés 0/2 870ms 7312 KiB
21 Időlimit túllépés 0/2 857ms 7608 KiB
22 Időlimit túllépés 0/2 861ms 7540 KiB