Heim Backend-Entwicklung C++ So verwenden Sie den Eight Queens Problem-Algorithmus in C++

So verwenden Sie den Eight Queens Problem-Algorithmus in C++

Sep 19, 2023 pm 12:07 PM
c++ 算法 Acht Königinnen

So verwenden Sie den Eight Queens Problem-Algorithmus in C++

So verwenden Sie den Acht-Damen-Problemalgorithmus in C++

Das Acht-Damen-Problem ist ein klassisches Algorithmusproblem, bei dem acht Königinnen auf einem 8x8-Schachbrett platziert werden müssen, sodass sich keine zwei Königinnen gegenseitig angreifen können, d. h. zwei beliebige Königinnen darf nicht in derselben Zeile, Spalte oder Diagonale liegen. Es gibt viele Algorithmen zur Lösung des Acht-Damen-Problems. Eine der häufigsten Methoden ist die Verwendung des Backtracking-Algorithmus. In diesem Artikel wird erläutert, wie die Sprache C++ zum Implementieren des Algorithmus des Acht-Damen-Problems verwendet wird, und es werden spezifische Codebeispiele bereitgestellt.

Zuerst müssen wir ein 8x8-Schachbrett definieren, das durch ein zweidimensionales Array dargestellt wird. Jedes Element des Arrays kann ein Schachbrettgitter darstellen. 1 bedeutet, dass es eine Königin auf dem Gitter gibt, 0 bedeutet, dass es keine Königin gibt.

Als nächstes definieren wir eine rekursive Funktion, um jede Reihe des Bretts zu durchlaufen und zu versuchen, die Königin zu platzieren. Die spezifischen Schritte sind wie folgt:

  1. Wenn Sie zur letzten Reihe des Schachbretts gelangt sind, bedeutet dies, dass Sie eine Lösung gefunden haben, den aktuellen Schachbrettstatus speichern und zurückkehren.
  2. Durchquere jedes Gitter in der aktuellen Reihe und versuche, die Königin zu platzieren.
  3. Wenn das aktuelle Gitter die Bedingungen für die Platzierung der Königin nicht erfüllt (d. h. es steht im Konflikt mit der bereits platzierten Königin), wird das aktuelle Gitter übersprungen und das nächste Gitter weiter durchquert.
  4. Wenn das aktuelle Gitter die Bedingungen für die Platzierung einer Königin erfüllt, platzieren Sie eine Königin auf dem Gitter und markieren Sie das Gitter als besetzt.
  5. Rufen Sie die Funktion rekursiv auf und durchlaufen Sie die nächste Zeile.
  6. Wenn das Ergebnis des rekursiven Aufrufs „true“ zurückgibt, bedeutet dies, dass eine Lösung gefunden wurde, dann wird die Lösung gespeichert und „true“ zurückgegeben.
  7. Wenn das Ergebnis des rekursiven Aufrufs „Falsch“ zurückgibt, bedeutet dies, dass die Platzierung des aktuellen Gitters nicht den Lösungsanforderungen entspricht. Entfernen Sie dann die Königin aus dem Gitter und kehren Sie zum vorherigen Schritt zurück.

Basierend auf den oben genannten Ideen können wir den folgenden Code implementieren:

#include <iostream>
#include <vector>

using namespace std;

const int n = 8;  // 棋盘大小

// 棋盘
int chessboard[n][n];

// 保存解法的容器
vector<vector<int>> solutions;

// 检查当前格子上是否可以放置皇后
bool isValid(int row, int col) {
    // 检查同一列上是否有皇后
    for (int i = 0; i < row; i++) {
        if (chessboard[i][col] == 1)
            return false;
    }
    
    // 检查左上对角线上是否有皇后
    for (int i = row, j = col; i >= 0 && j >= 0; i--, j--) {
        if (chessboard[i][j] == 1)
            return false;
    }
    
    // 检查右上对角线上是否有皇后
    for (int i = row, j = col; i >= 0 && j < n; i--, j++) {
        if (chessboard[i][j] == 1)
            return false;
    }
    
    return true;
}

// 解决八皇后问题的递归函数
bool solveNQueens(int row) {
    // 如果已经遍历到最后一行,表示找到了一种解法,将当前棋盘状态保存下来
    if (row == n) {
        vector<int> solution;
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < n; j++) {
                if (chessboard[i][j] == 1)
                    solution.push_back(j);
            }
        }
        solutions.push_back(solution);
        return true;
    }

    // 遍历当前行的每一个格子,尝试放置皇后
    for (int col = 0; col < n; col++) {
        // 如果当前格子满足放置皇后的条件,标记该格子为已占用
        if (isValid(row, col)) {
            chessboard[row][col] = 1;

            // 递归调用函数,遍历下一行
            solveNQueens(row + 1);

            // 如果递归调用的结果返回false,表示当前格子的放置方式不满足解法要求,回溯到上一步
            chessboard[row][col] = 0;
        }
    }

    return false;
}

// 打印解法
void printSolutions() {
    for (auto solution : solutions) {
        cout << "Solution:" << endl;
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < n; j++) {
                if (j == solution[i])
                    cout << "Q ";
                else
                    cout << ". ";
            }
            cout << endl;
        }
        cout << endl;
    }
}

int main() {
    solveNQueens(0);
    printSolutions();
    return 0;
}
Nach dem Login kopieren

Führen Sie dieses Programm aus und alle Lösungen werden ausgegeben. Jede Lösung wird in Form eines Schachbretts angezeigt, wobei Q die Dame und das Feld darstellt. Mit diesem Algorithmus können wir alle Lösungen des Acht-Damen-Problems finden.

Ich hoffe, dieser Artikel hilft Ihnen zu verstehen, wie Sie den Eight Queens Problem-Algorithmus in C++ verwenden. Die Implementierung dieses Algorithmus erfordert die Verwendung von Rekursions- und Backtracking-Ideen. Solange Sie die richtigen Schritte befolgen, können Sie die Lösung für das Acht-Damen-Problem finden.

Das obige ist der detaillierte Inhalt vonSo verwenden Sie den Eight Queens Problem-Algorithmus in C++. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Verbesserter Erkennungsalgorithmus: zur Zielerkennung in hochauflösenden optischen Fernerkundungsbildern Verbesserter Erkennungsalgorithmus: zur Zielerkennung in hochauflösenden optischen Fernerkundungsbildern Jun 06, 2024 pm 12:33 PM

01Ausblicksübersicht Derzeit ist es schwierig, ein angemessenes Gleichgewicht zwischen Detektionseffizienz und Detektionsergebnissen zu erreichen. Wir haben einen verbesserten YOLOv5-Algorithmus zur Zielerkennung in hochauflösenden optischen Fernerkundungsbildern entwickelt, der mehrschichtige Merkmalspyramiden, Multierkennungskopfstrategien und hybride Aufmerksamkeitsmodule verwendet, um die Wirkung des Zielerkennungsnetzwerks in optischen Fernerkundungsbildern zu verbessern. Laut SIMD-Datensatz ist der mAP des neuen Algorithmus 2,2 % besser als YOLOv5 und 8,48 % besser als YOLOX, wodurch ein besseres Gleichgewicht zwischen Erkennungsergebnissen und Geschwindigkeit erreicht wird. 02 Hintergrund und Motivation Mit der rasanten Entwicklung der Fernerkundungstechnologie wurden hochauflösende optische Fernerkundungsbilder verwendet, um viele Objekte auf der Erdoberfläche zu beschreiben, darunter Flugzeuge, Autos, Gebäude usw. Objekterkennung bei der Interpretation von Fernerkundungsbildern

Wie implementiert man das Strategy Design Pattern in C++? Wie implementiert man das Strategy Design Pattern in C++? Jun 06, 2024 pm 04:16 PM

Die Schritte zum Implementieren des Strategiemusters in C++ lauten wie folgt: Definieren Sie die Strategieschnittstelle und deklarieren Sie die Methoden, die ausgeführt werden müssen. Erstellen Sie spezifische Strategieklassen, implementieren Sie jeweils die Schnittstelle und stellen Sie verschiedene Algorithmen bereit. Verwenden Sie eine Kontextklasse, um einen Verweis auf eine konkrete Strategieklasse zu speichern und Operationen darüber auszuführen.

Wie implementiert man eine verschachtelte Ausnahmebehandlung in C++? Wie implementiert man eine verschachtelte Ausnahmebehandlung in C++? Jun 05, 2024 pm 09:15 PM

Die Behandlung verschachtelter Ausnahmen wird in C++ durch verschachtelte Try-Catch-Blöcke implementiert, sodass neue Ausnahmen innerhalb des Ausnahmehandlers ausgelöst werden können. Die verschachtelten Try-Catch-Schritte lauten wie folgt: 1. Der äußere Try-Catch-Block behandelt alle Ausnahmen, einschließlich der vom inneren Ausnahmehandler ausgelösten. 2. Der innere Try-Catch-Block behandelt bestimmte Arten von Ausnahmen, und wenn eine Ausnahme außerhalb des Gültigkeitsbereichs auftritt, wird die Kontrolle an den externen Ausnahmehandler übergeben.

Der bahnbrechende CVM-Algorithmus löst Zählprobleme aus über 40 Jahren! Informatiker wirft Münze, um einzigartiges Wort für „Hamlet' zu finden Der bahnbrechende CVM-Algorithmus löst Zählprobleme aus über 40 Jahren! Informatiker wirft Münze, um einzigartiges Wort für „Hamlet' zu finden Jun 07, 2024 pm 03:44 PM

Zählen klingt einfach, ist aber in der Praxis sehr schwierig. Stellen Sie sich vor, Sie werden in einen unberührten Regenwald transportiert, um eine Wildtierzählung durchzuführen. Wenn Sie ein Tier sehen, machen Sie ein Foto. Digitalkameras zeichnen nur die Gesamtzahl der verfolgten Tiere auf, Sie interessieren sich jedoch für die Anzahl der einzelnen Tiere, es gibt jedoch keine Statistiken. Wie erhält man also am besten Zugang zu dieser einzigartigen Tierpopulation? An diesem Punkt müssen Sie sagen: Beginnen Sie jetzt mit dem Zählen und vergleichen Sie schließlich jede neue Art vom Foto mit der Liste. Für Informationsmengen bis zu mehreren Milliarden Einträgen ist diese gängige Zählmethode jedoch teilweise nicht geeignet. Informatiker des Indian Statistical Institute (UNL) und der National University of Singapore haben einen neuen Algorithmus vorgeschlagen – CVM. Es kann die Berechnung verschiedener Elemente in einer langen Liste annähern.

Wie verwende ich die C++-Vorlagenvererbung? Wie verwende ich die C++-Vorlagenvererbung? Jun 06, 2024 am 10:33 AM

Durch die Vererbung von C++-Vorlagen können von Vorlagen abgeleitete Klassen den Code und die Funktionalität der Basisklassenvorlage wiederverwenden. Dies eignet sich zum Erstellen von Klassen mit derselben Kernlogik, aber unterschiedlichen spezifischen Verhaltensweisen. Die Syntax der Vorlagenvererbung lautet: templateclassDerived:publicBase{}. Beispiel: templateclassBase{};templateclassDerived:publicBase{};. Praktischer Fall: Erstellt die abgeleitete Klasse Derived, erbt die Zählfunktion der Basisklasse Base und fügt die Methode printCount hinzu, um die aktuelle Zählung zu drucken.

Was ist die Rolle von CHAR in C -Saiten? Was ist die Rolle von CHAR in C -Saiten? Apr 03, 2025 pm 03:15 PM

In C wird der Zeichenentyp in Saiten verwendet: 1. Speichern Sie ein einzelnes Zeichen; 2. Verwenden Sie ein Array, um eine Zeichenfolge darzustellen und mit einem Null -Terminator zu enden. 3. Durch eine Saitenbetriebsfunktion arbeiten; 4. Lesen oder geben Sie eine Zeichenfolge von der Tastatur aus.

Warum tritt bei der Installation einer Erweiterung mit PECL in einer Docker -Umgebung ein Fehler auf? Wie löst ich es? Warum tritt bei der Installation einer Erweiterung mit PECL in einer Docker -Umgebung ein Fehler auf? Wie löst ich es? Apr 01, 2025 pm 03:06 PM

Ursachen und Lösungen für Fehler Bei der Verwendung von PECL zur Installation von Erweiterungen in der Docker -Umgebung, wenn die Docker -Umgebung verwendet wird, begegnen wir häufig auf einige Kopfschmerzen ...

Wie gehe ich mit Thread-übergreifenden C++-Ausnahmen um? Wie gehe ich mit Thread-übergreifenden C++-Ausnahmen um? Jun 06, 2024 am 10:44 AM

In Multithread-C++ wird die Ausnahmebehandlung über die Mechanismen std::promise und std::future implementiert: Verwenden Sie das Promise-Objekt, um die Ausnahme in dem Thread aufzuzeichnen, der die Ausnahme auslöst. Verwenden Sie ein zukünftiges Objekt, um in dem Thread, der die Ausnahme empfängt, nach Ausnahmen zu suchen. Praktische Fälle zeigen, wie man Versprechen und Futures verwendet, um Ausnahmen in verschiedenen Threads abzufangen und zu behandeln.

See all articles