回溯法求解八皇后问题

#include <stdio.h>
#include <stdlib.h>
#define N 8

int column[N+1]; // 同栏是否有皇后,1表示有
int rup[2*N+1]; // 右上至左下是否有皇后
int lup[2*N+1]; // 左上至右下是否有皇后
int queen[N+1] = {0};
int num; // 解答编号

void backtrack(int); // 递回求解

int main(void) {
    int i;
    num = 0;

    for(i = 1; i <= N; i++)
        column[i] = 1;

    for(i = 1; i <= 2*N; i++)
        rup[i] = lup[i] = 1;

    backtrack(1);

    return 0;
}

void showAnswer() {
    int x, y;
    printf("\n解答 %d\n", ++num);
    for(y = 1; y <= N; y++) {
        for(x = 1; x <= N; x++) {
            if(queen[y] == x) {
                printf(" Q");
            }
            else {
                printf(" .");
            }
        }
        printf("\n");
    }
}

void backtrack(int i) {
    int j;

    if(i > N) {
        showAnswer();
    }
    else {
        for(j = 1; j <= N; j++) {
            if(column[j] == 1 &&
                 rup[i+j] == 1 && lup[i-j+N] == 1) {
                queen[i] = j;
                // 设定为占用
                column[j] = rup[i+j] = lup[i-j+N] = 0;
                backtrack(i+1);
                column[j] = rup[i+j] = lup[i-j+N] = 1;
            }
        }
    }
}

http://www.oschina.net/code/snippet_234517_12132

转载于:https://my.oschina.net/u/1423127/blog/277306

八皇后问题是一个经典的回溯问题,以下是求解该问题的代码: ```python class EightQueens: def __init__(self, n): self.n = n # 棋盘大小 self.solution = [-1] * n # 解法数组 def is_valid(self, row, col): # 判断当前位置是否合法 for i in range(row): # 判断同一列是否有皇后 if self.solution[i] == col: return False # 判断对角线是否有皇后 if abs(i - row) == abs(self.solution[i] - col): return False return True def backtrack(self, row): # 找到解法 if row == self.n: print(self.solution) return # 遍历每一列 for col in range(self.n): # 判断当前位置是否合法 if self.is_valid(row, col): self.solution[row] = col # 继续寻找下一行的解法 self.backtrack(row + 1) # 回溯 self.solution[row] = -1 def solve(self): self.backtrack(0) if __name__ == '__main__': n = 8 eight_queens = EightQueens(n) eight_queens.solve() ``` 在这个代码中,我们定义了一个 EightQueens 类,其中包含了 is_valid 和 backtrack 两个函数。is_valid 函数用来判断当前位置是否合法,backtrack 函数用来回溯求解八皇后问题。 在主函数中,我们创建了一个 EightQueens 对象,然后调用了 solve 函数来求解八皇后问题求解过程中,我们遍历每一行,对于每一行,我们遍历每一列,判断当前位置是否合法,如果合法,就将皇后放置在该位置,然后继续寻找下一行的解法。如果找到了解法,就输出解法。如果没有找到解法,就回溯到上一行,重新寻找解法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值