Ich programmiere derzeit eine AI für das Spiel Hex. Die Karte wird durch ein Array der Länge 121 dargestellt. Während der Simulationsphase der Monte-Carlo-Baumsuche extrahiere ich die möglichen Züge.
Ich Schleife nur über das Array und extrahiere den Index, wo ein Wert 0 gefunden wurde. (Mögliche Werte sind 1, -1,0)Extrahieren 0 Werte aus Array
std::vector<unsigned char>moveListe;
moveListe.reserve(121 - board->moveCount);
for (unsigned char i = 0; i<121; i++) {
if (board->board[i] != EMPTY) {
continue;
}
moveListe.push_back(i);
}
Gibt es eine Möglichkeit, dies zu beschleunigen?
Haben Sie eine Frage? –
@ manni66: Sry, ich hatte es eilig. Ich habe meinen obigen Text bearbeitet – CheckersGuy
Warum müssen Sie es beschleunigen? Wenn Sie Probleme mit Ihrem Code haben, brauchen Sie wahrscheinlich viel mehr Informationen darüber, warum dieser Code Ihren Anforderungen nicht entspricht und wie schnell Sie ihn benötigen. – Tas