Algorithm serialization (4) - back tttramne N Queens

xiaoxiao2021-03-05  21

1. Problem Description: Place n queen on a N * N board, and make each two cannot attack each other, that is, each two is not in the same row, the same column and the same bevel line.

2. Design Thought and Analysis: Basic Ideas: X (j) means a space of the solution, J represents the number of rows, the value inside means that the number of columns can be placed, the abstract constraint condition gets the constraints that can be placed (1) X (i)! = X (k); (2) ABS (x (i) -X (k))! = ABS (IK). Applying a backtracking method, when you can put the queen, continue until the next line, return to the first line, re-test the number of columns to put, until all disserted.

#include #include

/ * Check that you can place a new queen * / bool place (int K, int * x) {INT i; i = 1; while (i 0) {x [k] = x [k] 1; while (x [k] <= n) && Place (k, x))) x [k] = x [k] 1; if (x [k] <= n) IF (k == n) {for (int i = 1; i <= n ; i ) cout << x [i] << ""; cout << "/ n";} else {k = k 1; x [k] = 0;} else k = k-1;}}

Void main () {cout << "| -------------- N Queen question -------------- |" << endl; cout << "| --- Power by zhanjianTao (028054115) --- |" << endl; cout << "| ------------------------- ------------ | "<< endl << endl; int N; int * x; int i; while (i) {cout <<" Please enter the queen of the queen: "CIN >> N; x = new int [n]; the solution to the COUT << "problem:" << endl; nqueens (n, x); cout << "Press <1> to run again << Endl; cout << "Press <0> to exit" << Endl; CIN >> I;}}

转载请注明原文地址:https://www.9cbs.com/read-36273.html

New Post(0)