Я работаю над тральщиком для школьного проекта. В настоящее время я работаю над открытием соседних квадратов, если число мин в смежных квадратах равно 0. Я написал для этого функцию.
{
void Square::openAdjacent(int a, int b)
{
for (int i=(a-1); i<=(a+1); i++)
{
for (int j= (b-1); j<=(b+1); j++)
{
if ((i==a && j==b) || (i<=0) || (j<=0) || (i>=board_->size()) || (j>=board_->size())){}
else if (not board_->at(j).at(i).opened_ && count_==0 && (opened_) && (not board_->at(j).at(i).hasMine_)){
board_->at(j).at(i).opened_=true;
if (board_->at(j).at(i).count_==0){
openAdjacent(i, j);
}
}
}
}
}
}
Как вы можете видеть, я вызывал функцию openAdjacent внутри этой же функции. Я прочитал вокруг и узнал, что это невозможно в C ++. Я хотел бы знать, возможно ли обойти эту проблему и как мне это сделать.