N皇后问题的求解(C++代码)

本文介绍了一种使用回溯法解决八皇后问题的算法,并提供了一个具体的C++实现示例。通过递归地放置皇后并检查冲突来找到所有可能的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

八皇后问题是把八个皇后放到棋盘中,使它们不互相攻击.根据国际象棋的规则,皇后可以吃掉放在和它同行,同列,或同一斜线上的任一棋子.

八皇后求解的核心算法伪代码:

putqueen(row)

for(同一行row上每个位置col)

if 位置col可以放皇后

将下一个皇后放在位置col处

if(row<8)

putqueen(row+1)

else 成功

取走位置col上的皇后

具体代码如下:

 

Code:
  1. #include <iostream>   
  2. using namespace std;   
  3.   
  4. int p[12][12];//初始化棋盘(棋盘太大回溯法的效率很低,所以该题的数据很小)   
  5. int result;   
  6. int n;//棋盘大小   
  7.   
  8. void init(int n)//初始化棋盘   
  9. {   
  10.     for(int i=0;i<n;i++)   
  11.     {   
  12.         for(int j=0;j<n;j++)   
  13.             p[i][j]=0;   
  14.     }   
  15.     result=0;   
  16. }   
  17.   
  18. bool issafe(int row,int col)//判断该位置能否放皇后   
  19. {   
  20.     for(int i=0;i<row;i++)   
  21.     {   
  22.         for(int j=0;j<n;j++)   
  23.         {   
  24.             if(p[i][j]==1)   
  25.             {   
  26.                 //判断同行,同列,对角线上是否有皇后   
  27.                 if(i==row||j==col||(j-i)==(col-row)||(j+i)==(col+row))   
  28.                     return false;   
  29.             }   
  30.         }   
  31.     }   
  32.     return true;   
  33. }   
  34.   
  35. void putqueen(int x)//入皇后   
  36. {   
  37.     for(int y=0;y<n;y++)//遍历该行每个位置   
  38.     {   
  39.         if(issafe(x,y))//如果安全    
  40.         {   
  41.             p[x][y]=1;//则放皇后   
  42.             if(x<n-1)   
  43.                 putqueen(x+1);//如果未到最后一行,在下一行放皇后   
  44.             else  
  45.                 result++;//否则返回,结果加1   
  46.         }   
  47.         {   
  48.             for(int k=0;k<n;k++)//该步骤很重要,拿走该行上的皇后   
  49.             p[x][k]=0;   
  50.         }   
  51.     }   
  52. }   
  53.            
  54.   
  55. int main()   
  56. {   
  57.   
  58.     while(cin>>n)   
  59.     {   
  60.         init(n);   
  61.         putqueen(0);   
  62.         cout<<result<<endl;   
  63.     }   
  64.     return 0;   
  65. }  

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值