이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define pb push_back
using namespace std;
const int N = (1 << 13);
int nPartis[N * 2];
int tTree;
void partir(int ind, int delta){
for (int noeud = tTree + ind; noeud > 0; noeud /= 2)
nPartis[noeud] += delta;
}
int getKth(int noeud, int tailleInter, int k){ //Le 1 est le premier
if (noeud >= tTree)
return noeud - tTree;
int nGauche = tailleInter/2 - nPartis[noeud * 2];
if (k > nGauche)
return getKth(noeud * 2 + 1, tailleInter/2, k - nGauche);
return getKth(noeud * 2, tailleInter/2, k);
}
int GetBestPosition(int nGars, int nRounds, int rangPaume, int *rangs, int *gauche, int *droite) {
int tempsOpt = -1, iOpt = -1;
tTree = (1 << ((int)ceil(log2(nGars))));
for (int depart = 0; depart < nGars; ++depart){
for (int ind = 0; ind < 2 * tTree; ++ind)
nPartis[ind] = 0;
vector<int> rangsCur;
for (int ind = 0; ind < depart; ++ind)
rangsCur.pb(rangs[ind]);
rangsCur.pb(rangPaume);
for (int ind = depart; ind < nGars - 1; ++ind)
rangsCur.pb(rangs[ind]);
/*
cout << "depart " << depart << endl;
for (int rang : rangsCur)
cout << rang << " ";
cout << endl;
*/
int nWins = 0, gagnant = -1;
for (int iRound = 0; iRound < nRounds; ++iRound){
vector<int> participants;
for (int ind = gauche[iRound] + 1; ind <= droite[iRound] + 1; ++ind)
participants.pb(getKth(1, tTree, ind));
int iBest = -1;
for (int participant : participants){
if (iBest == -1 || (rangsCur[participant] > rangsCur[iBest]))
iBest = participant;
}
if (iBest == depart)
nWins++;
for (int participant : participants){
if (participant != iBest)
partir(participant, 1);
}
gagnant = iBest;
}
if (nWins > tempsOpt){
tempsOpt = nWins;
iOpt = depart;
}
for (int ind = 0; ind < nGars; ++ind)
if (ind != gagnant)
partir(ind, -1);
}
return iOpt;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |