N皇后问题-回溯法-C语言

article/2025/10/6 0:58:26

关于对N皇后问题和回溯法的理解 个人非常推荐下面这个视频:算法与数据结构,回溯法求解八皇后,最经典的递归问题_哔哩哔哩_bilibili八皇后问题是计算机科学中最为经典的问题之一,该问题由国际西洋棋棋手马克斯·贝瑟尔于1848年提出。八皇后问题,即在8×8的国际象棋盘上摆放八个皇后,使其不能互相攻击,任意两个皇后都不能处于同一行、同一列或同一斜线上,求出一共有多少种摆放方式,每种摆放方式的具体摆法。https://www.bilibili.com/video/BV1ZK411K7A8?share_source=copy_web

视频中的代码使用C++写的,个人接触嵌入式较多所以比较习惯用C

C语言代码如下:

/* N皇后问题 */#include <stdio.h>#include <stdlib.h>#define N 100 //宏定义最大的Nint attack[N][N];char queen[N][N];int cnt;void init(int n);//初始化attack和queen数组void print(int n);//打印符合要求的摆法void print_ack(int n);//测试update_ack函数编写是否正确void copy(int object[N][N],int target[N][N],int n);//将对象数组保存给目标数组void update_ack(int x,int y,int n);//摆放queen后更新attack数组,将进queen攻路线上的值标为1void backtrack(int row,int n);//回溯法 递归调用int main(int argc, char const *argv[]){int n;puts("Please input the N of queen:");scanf("%d",&n);//计算nXn的皇后问题init(n);//初始化attack和queen数组backtrack(0,n);//从第0行开始摆放queenprintf("The number of required placement method =%d\n",cnt);system("pause");return 0;}void backtrack(int row,int n){if(row==n)//递归执行到摆放完所有行的结束条件{cnt++;print(n);return ;}int col;for(col=0;col<n;col++){if(attack[row][col]==0)//判断该位置是能够放置queen{int tem[N][N];//保存当前的attack数组内容,便于回溯copy(attack,tem,n);//遍历交换queen[row][col]='Q';//该位置放置queenupdate_ack(row,col,n);//放置完后将棋盘上queen的进攻路线全部标为1backtrack(row+1,n);//行数+1,递归回到函数头部重复判断//递归结束才会执行下面的语句copy(tem,attack,n);//将之前保存的temp返还给attackqueen[row][col]='.';//将标记的Q改回.}}}void init(int n)//初始化attack和queen数组{int i,j;for(i=0;i<n;i++)//对二维数组遍历for(j=0;j<n;j++){attack[i][j]=0;queen[i][j]='.';}}void print(int n)//打印符合要求的摆法{int i,j;printf("cnt=%d\n",cnt);for(i=0;i<n;i++){for(j=0;j<n;j++){printf("%c\t",queen[i][j]);}printf("\n");}printf("\n");}void print_ack(int n)//测试update_ack函数编写是否正确{int i,j;for(i=0;i<n;i++)//对二维数组遍历{for(j=0;j<n;j++){printf("%d\t",attack[i][j]);}printf("\n");//每打印出n个换行}}void copy(int object[N][N],int target[N][N],int n)//将对象数组保存给目标数组{int i,j;for(i=0;i<n;i++){for(j=0;j<n;j++){target[i][j]=object[i][j];}}/*    for(i=0;i<n;i++){for(j=0;j<n;j++){printf("%d\t",tem[i][j]);}printf("\n");} */}void update_ack(int x,int y,int n){int i,j,nx,ny;int dx[8]={-1,0,1,-1,  1,-1,0,1};//dx,dy的八对数 分别对应int dy[8]={-1,-1,-1,0, 0, 1, 1,1 };//左上,上,右上,左,右,左下,下,右下,八个方向attack[x][y]=1;for(i=1;i<n;i++){for(j=0;j<8;j++){nx=x+i*dx[j];ny=y+i*dy[j];if(nx>=0 && nx<n && ny>=0 && ny<n )//nx,ny判断是否在棋盘内,满足才将对应的位标记{attack[nx][ny]=1;}}}// print_ack(n);测试代码}

(N可以随意取,大于100的话需要修改宏定义 #define N 100 )

代码运行结果:

如果这篇Blog有帮到你,请点个赞再走,Respect 所有帮到过我的博客作者!


http://chatgpt.dhexx.cn/article/eEWS1PcG.shtml

相关文章

Java——N皇后问题

题目链接 leetcode在线oj题——N皇后 题目描述 按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 给你一个整数 n &#xff…

N 皇后问题

n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 给你一个整数 n &#xff0c;返回所有不同的 n 皇后问题 的解决方案。 每一种解法包含一个不同的 n 皇后问题 的棋子放置方案&#xff0c;该方案中 Q 和 . 分别代表了皇后和…

N皇后问题(C++)

n−皇后问题是指将 n 个皇后放在 nn 的国际象棋棋盘上&#xff0c;使得皇后不能相互攻击到&#xff0c;即任意两个皇后都不能处于同一行、同一列或同一斜线上。 现在给定整数 n&#xff0c;请你输出所有的满足条件的棋子摆法。 输入格式 共一行&#xff0c;包含整数 n。 输出…

回溯法求解n皇后问题

一、实验目的 1&#xff0e;掌握能用回溯法求解的问题应满足的条件&#xff1b; 2&#xff0e;加深对回溯法算法设计方法的理解与应用&#xff1b; 3&#xff0e;锻炼学生对程序跟踪调试能力&#xff1b; 4&#xff0e;通过本次实验的练习培养学生应用所学知识解决实际问题的能…

N皇后问题(java)

n皇后问题是一个以国际象棋为背景的问题&#xff1a;在nn的国际象棋棋盘上放置n个皇后&#xff0c;使得任何一个皇后都无法直接吃掉其他的皇后&#xff0c;即任意两个皇后都不能处于同一条横行、纵行或斜线上。 我们通过回溯的方法将所有可能的情况遍历一遍 假设现在有一个4*4…

N皇后问题(Python实现)

n 皇后问题研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 也就是说&#xff1a;存在一个N*N的棋盘&#xff0c;要放N个棋子&#xff0c;每个棋子不同行&#xff0c;不同列&#xff0c;不同&#xff08;正反&#xff09;对角线&…

数据结构之N皇后问题(C语言)

一、N皇后问题的概念 n 皇后问题&#xff0c;研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 一个皇后可以向水平、垂直以及向斜对角方向移动&#xff0c;如果一个皇后出现在另一个皇后的同一行&#xff0c;同一列或者斜对角&#x…

n皇后问题 C++

先上代码&#xff01; #include<iostream> using namespace std;const int N 20;int n; bool row[N],col[N], dg[N], udg[N]; char g[N][N];void dfs(int x, int y, int z) {if (y n) y 0, x; //判断y是否已经抵达边界&#xff0c;抵达后&#xff0c;x1进行下一行if …

回溯法-N皇后问题

一、N皇后问题 n皇后问题&#xff1a;要求在一个nn的棋盘上放置n个皇后&#xff0c;使得任意两个皇后不在同一行或同一列或同一斜线上。 二、回溯法 回溯法是一类非常重要的算法设计方法&#xff0c;有“通用解题法”之称。 回溯法&#xff08;探索与回溯法&#xff09;&am…

(新手向)N皇后问题详解(DFS算法)

非常经典的一道题&#xff1a; N皇后问题&#xff1a; 国际象棋中皇后的势力范围覆盖其所在的行、列以及两条对角线&#xff0c;现在考察如下问题&#xff1a;如何在n x n的棋盘上放置n个皇后&#xff0c;使得她们彼此互不攻击 。 免去麻烦我们这里假定n不是很大。。 &#…

n皇后问题-c语言实现

n皇后问题描述为:在一个nxn的棋盘上摆放n个皇后&#xff0c;要求任意两个皇后不能冲突&#xff0c;即任意两个皇后不在同一行、同一列或者同一斜线上。 1,1 1,2 1,3 1,4 2,1 2,2 2,3 2,4 3,1 3,2 3,3 3,4 4,1 4,2 4,3 4,4 上面是4皇后摆放方案&#xff0c;只有…

n皇后问题合集

八皇后问题是dfs的经典问题&#xff0c;目前遇到过的类型大致有这么几种&#xff1a; 1.经典n皇后问题 题目描述 n−皇后问题是指将 n 个皇后放在 nn 的国际象棋棋盘上&#xff0c;使得皇后不能相互攻击到&#xff0c;即任意两个皇后都不能处于同一行、同一列或同一斜线上。 …

N皇后问题(c语言实现)

问题描述&#xff1a; 有一个n*n的棋盘&#xff0c;在这个棋盘中放n个皇后&#xff0c;使得这n个皇后&#xff0c;任意两个皇后不在同一行&#xff0c;同一列&#xff0c;同一条对角线。例如&#xff0c;当n等于4时&#xff0c;有两种摆法。 输入只有一个整数n。 思路 如果…

N皇后问题

问题描述 n 皇后问题研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 上图为 8 皇后问题的一种解法。 给定一个整数 n&#xff0c;返回所有不同的 n 皇后问题的解决方案。 每一种解法包含一个明确的 n 皇后问题的棋子放置方案&#…

回溯算法之N皇后问题

问题描述 什么是皇后问题(有一定了解可以直接跳过这个部分看求解部分哦) 八皇后问题&#xff08;英文&#xff1a;Eight queens&#xff09;&#xff0c;是由国际西洋棋棋手马克斯贝瑟尔于1848年提出的问题&#xff0c;是回溯算法的典型案例。 问题表述为&#xff1a;在88格的…

N皇后问题(分支限界法)

问题描述&#xff1a; 在 n * n 格的棋盘上放置彼此不受攻击的 n 个皇后。按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题等价于在 n * n 的棋盘上放置 n 个皇后&#xff0c;任何 2个皇后不放在同一行或同一列或同一斜线上…

N皇后问题详解

文章目录 一、题目描述二、题目解析&#xff08;1&#xff09;思考一(集合回溯)&#xff08;2&#xff09;思考二(数组深度递归)&#xff08;3&#xff09;思考三(位运算) 一、题目描述 N 皇后问题是指在 n * n 的棋盘上要摆 n 个皇后&#xff0c; 要求&#xff1a;任何两个皇…

3.2 回溯法—N皇后问题

1. 问题描述 在 n n n\times n nn的棋盘上摆放 n n n个皇后&#xff0c;使任意两个皇后都不能处于同一行、同一列或同一斜线上 2. 问题分析 下以求解4皇后问题为例&#xff0c;分析4皇后问题的排列树以及回溯过程&#xff1a; 搜索及回溯过程&#xff1a; 解空间树&#…

【经典算法】N皇后问题

✨前言✨ N皇后问题经典的解决方案是暴力递归&#xff0c;其时间复杂度是O(2^n),因此常用来测试计算机的算力。今天我会给大家带来经典方法的详解&#xff0c;也会给大家展示N皇后优化后的大神解法。做一道经典题目&#xff0c;来一场思维旅行。 目录 ✨前言✨ &#x1f4a1;…

n皇后问题(回溯法)(超易理解)(详细注释)

问题&#xff1a; N皇后问题是一个经典的问题&#xff0c;描述如下&#xff1a; 在的方格棋盘需要放置N个皇后&#xff0c;使得它们不相互攻击&#xff0c; 即任意2个皇后不允许处在同一排&#xff0c;同一列&#xff0c;也不允许处在与棋盘边框成45度角的斜线上。 对于给定的N…