C++八皇后问题代码

cpp 复制代码
#include <iostream>
#include <cmath>
using namespace std;

// 判断能否放置皇后
bool canPlace(int q[], int n, int i) {
    for (int j = 0; j < n; j++) {
        // 判断是否在同一行或同一列
        if (q[j] == i || abs(q[j] - i) == abs(j - n)) {
            return false;
        }
    }
    return true;
}

// 解决八皇后问题
void solve(int q[], int n, int& count) {
    if (n == 8) {
        count++;
        // 输出解决方案
        cout << "Solution " << count << ":" << endl;
        for (int i = 0; i < 8; i++) {
            for (int j = 0; j < 8; j++) {
                if (q[i] == j) {
                    cout << "Q ";
                } else {
                    cout << ". ";
                }
            }
            cout << endl;
        }
        cout << endl;
        return;
    }
    for (int i = 0; i < 8; i++) {
        if (canPlace(q, n, i)) {
            q[n] = i;
            solve(q, n + 1, count);
        }
    }
}

int main() {
    int q[8] = {0};
    int count = 0;
    solve(q, 0, count);
    return 0;
}

运行:

cpp 复制代码
Solution 1:
Q . . . . . . . 
. . . Q . . . . 
. . . . . . Q . 
. . . . . . . Q 
. Q . . . . . . 
. . . . . Q . . 
. . Q . . . . . 
. . . . Q . . . 

Solution 2:
Q . . . . . . . 
. . . . Q . . . 
. . . . . . Q . 
. . . . . . . Q 
. . . Q . . . . 
. . . . . . . Q 
. Q . . . . . . 
. . . . . Q . . 
...

Solution 92:
. . . Q . . . . 
. . . . . . Q . 
Q . . . . . . . 
. . . . . . . Q 
. . . . Q . . . 
. Q . . . . . . 
. . . . . Q . . 
. . . . . . . Q 

使用回溯算法来解决八皇后问题。使用一个数组q来存储每个皇后的位置,尝试递归放置每个皇后,如果当前解决方案不可行,则回溯到上一个皇后位置并重新尝试。如果找到一个可行方案,则输出并继续尝试其他方案。

相关推荐
DeepModel43 分钟前
【概率分布】Beta分布详解
算法·概率论
娇娇yyyyyy43 分钟前
Qt编程(3): 信号和槽函数
开发语言·数据库·qt
wwww.wwww1 小时前
qt程序执行时报错:无法定位程序输入点,但是通过IDE的run又可以正常的运行。
开发语言·ide·qt
我命由我123451 小时前
React - 验证 Diffing 算法、key 的作用
javascript·算法·react.js·前端框架·html·html5·js
乌鸦乌鸦你的小虎牙4 小时前
qt 5.12.8 配置报错(交叉编译环境)
开发语言·数据库·qt
feifeigo1234 小时前
Leslie人口模型MATLAB实现(中长期人口预测)
开发语言·matlab
写代码的二次猿4 小时前
安装openfold(顺利解决版)
开发语言·python·深度学习
一只大袋鼠4 小时前
Redis 安装+基于短信验证码登录功能的完整实现
java·开发语言·数据库·redis·缓存·学习笔记
70asunflower4 小时前
CUDA编程指南基础知识点总结(5)
c++·人工智能·cuda
Eward-an4 小时前
LeetCode 1980 题通关指南|3种解法拆解“找唯一未出现二进制串”问题,附Python最优解实现
python·算法·leetcode