55072023-07-04 00:08:39AndrosKártyajátékcpp17Accepted 30/3085ms7444 KiB
#include <iostream>
#include <vector>
#include <algorithm>
#define ll long long

//Oktatas.hu-rol ujrairva
//Magyarazattal
//Van egy talan erthetobb megoldas feltoltve,
//csak idolimit tullepes, mert kellenek az iteratoros magiak, hogy gyors legyen
//termeszetesen oktatas.hu-rol
using namespace std;

int main()
{

	ll n, k;
	cin >> n >> k;
	vector<ll> hand(k);//Osszes kartya

	//Beolvasas
	for (int i = 0; i < k; i++)
	{
		cin >> hand[i];
	}


	vector<ll> pontszerzok;
	//Ebbe lesznek belerakva a kartyak, amik szerezhettek pontot, de nem biztos hogy szerztek.
	//A hand tomb azon elemei lesznek benne a vegen, amik elott nem volt nagyobb kartya.
	//Pl 1 8 3 15 4 20 sorozat vegen a 20-as szerezhetne pontot, ha lenne ott egy 16-os
	vector<bool> pont(k);//Egy-egy kartya adott-e pontot

	for (ll card : hand) {
		//Visszaadja a helyet az elso `card`-nal nagyobb szamnak a pontszerzokbol.
		auto it = upper_bound(pontszerzok.begin(), pontszerzok.end(), card);
		if (it == pontszerzok.end()) {
			//`pontszerzok.end()`-et ad vissza, ha nem volt nagyobb
			//Ha nem volt nagyobb, lementve eddig, akkor szerezhet majd pontot
			//Lementjuk a pontszerzok tablaba
			pontszerzok.push_back(card);
		}
		else {
			//Ha volt nala nagyobb
			//Az elso olyan kartyat adja vissza, ami nala nagyobb a pontszerzokbol.
			//Ez az elsonek nala nagyobb kartya vette ki ot a paklibol,
			//azaz az a kartya tuti szerzett pontot.

			//Beallitjuk, hogy szerzett pontot.
			pont[it - pontszerzok.begin()] = true;
		}


	}
	//Osszeszamoljuk hogy mennyi kartya szerzett tenylegesen pontot.
	int sum = 0;
	for (bool b : pont) {
		if (b) sum += 1;
	}
	cout << sum;

}
SubtaskSumTestVerdictTimeMemory
base30/30
1Accepted0/03ms1808 KiB
2Accepted0/085ms4820 KiB
3Accepted1/13ms2236 KiB
4Accepted1/13ms2432 KiB
5Accepted1/13ms2648 KiB
6Accepted2/23ms3020 KiB
7Accepted2/23ms3000 KiB
8Accepted2/23ms3080 KiB
9Accepted1/130ms4292 KiB
10Accepted2/245ms6084 KiB
11Accepted3/343ms6324 KiB
12Accepted3/345ms6292 KiB
13Accepted1/183ms5192 KiB
14Accepted2/285ms5776 KiB
15Accepted3/382ms7444 KiB
16Accepted3/385ms6412 KiB
17Accepted3/385ms6412 KiB