洛谷 P1219 八皇后 ( DFS

简单的DFS 回溯判断三个方向就可以了 很久很久以前谢过了 复习一下,,

AC代码

#include <bits/stdc++.h>
using namespace std;

// mps[i]=j 表示第i行到第j列有一个棋子
// vis[0] 储存棋子的列数 vis[1], vis[2] 表示 对角线上面的情况
int mps[100];
bool vis[3][100];
int sum = 0;
int n;

void dfs(int x) {
    if(x > n) {
        sum++;
        if(sum > 3) {
            return;
        }
        else {
            for(int i = 1; i < n; i++) {
                cout << mps[i] << " ";
            }
            cout << mps[n] << endl;
        }
    }
    for(int i = 1; i <= n; i++) {
        if((!vis[0][i]) && (!vis[1][x+i]) && (!vis[2][x-i+n])) {
            mps[x] = i;
            vis[0][i] = true; vis[1][x+i] = true; vis[2][x-i+n] = true;
            dfs(x+1);
            vis[0][i] = false; vis[1][x+i] = false; vis[2][x-i+n] = false;
        }
    }
}

int main() {
    cin >> n;
    dfs(1);
    cout << sum << endl;
return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
洛谷八皇后问题是一个经典的回溯算法问题。根据引用中的描述,要求将8个皇后放置在8*8棋盘上,使得它们彼此不受攻击,即任何两个皇后都不在同一行、同一列或同一斜线上。 引用[2]给出了一个c++代码的实现。这段代码使用了回溯法来解决八皇后问题。通过递归地尝试每一行中的每一列,找到合适的位置来放置皇后。 具体的过程如下: 1. 定义一个一维数组x,用来存储每行皇后的位置。 2. 从第一行开始递归,尝试每一列的位置。 3. 对于每个位置,检查是否与之前的皇后位置冲突,即是否在同一列或同一对角线上。如果冲突,就继续尝试下一列;如果不冲突,就将该位置存入数组x,并继续递归下一行。 4. 当递归到最后一行时,打印出当前的皇后位置,并将可行解的数量加一。 5. 回溯到上一行,尝试下一个列的位置。 6. 当所有的解都找到后,输出解的数量。 根据引用给出的代码,共有92种不同的放置方式,即解的数量为92。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [8皇后_八皇后问题c++实现_](https://download.csdn.net/download/weixin_42665725/26278676)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [八皇后问题C++递归回溯法(注解)](https://blog.csdn.net/qq_43656233/article/details/105571396)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值