日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

八皇后问题 (递归 搜索)

發布時間:2025/7/14 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 八皇后问题 (递归 搜索) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
八皇后問題:要在國際象棋棋盤8*8中放八個皇后,使任意兩個皇后都不能互相吃。(提示:皇后能吃同一行、同一列、同一對角線的任意棋子。) /*分析:每一列,每一行,每一個對角線只能放一個皇后,判斷對角線是否能放的條件是兩個皇后橫縱坐標的和或者是差不能相等,若相等,則在一個對角線,不能放置,每放一個皇后,都要占領他所在的行,列,對角線*/ 代碼如下:

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<iomanip>
using namespace std;
bool d1[100],d2[100],l[100];
int a[100];
int total;
int search(int);
int print();
int main()
{
search(1);//從第一個皇后開始放(很像素數環從第一個開始填,我們都是從簡單的開始,從什么地方開始遞歸很重要)
return 0;
}
int search(int x)//放第x個皇后,或者說是放第x行上的皇后(8個皇后一共8行,一定1行1個)
{
for(int i=1;i<=8;i++)//尋找可以放置的列數
if((!l[i])&&(!d1[i+x])&&(!d2[x-i+7]))//如果第i列沒有被放置,且兩個對角線沒有被占領;
{
a[x]=i;//第x個皇后在第i列
l[i]=1;//占領列數
d1[i+x]=1;//占領對角線
d2[x-i+7]=1;
if(x==8)print();//當放滿8個或者說是每一行都有皇后輸出
else
search(x+1);//沒放完,繼續放下一個
l[i]=0;//回溯
d1[x+i]=0;
d2[x-i+7]=0;
}
}
int print()//輸出
{
total++;
cout<<"sum="<<total<<endl;
for(int i=1;i<=8;i++)
cout<<setw(4)<<a[i];//注意setw頭文件是iomanip;
cout<<endl;
}

//和素數環很像,都是有幾個空,然后從第一個開始填,只是能填的條件不一樣;

轉載于:https://www.cnblogs.com/zzyh/p/6604374.html

總結

以上是生活随笔為你收集整理的八皇后问题 (递归 搜索)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。