亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

回溯法之二---8皇后問題

系統 2273 0

回溯法之二---8皇后問題

八皇后問題是一個古老而著名的問題,是回溯算法的典型例題。該問題是十九世紀著名的數學家高斯1850年提出:在8X8格的國際象棋上擺放八個皇后,使其不能互相攻擊,即任意兩個皇后都不能處于同一行、同一列或同一斜線上.
問題分析:
第一步 定義問題的解空間
這個問題解空間就是8個皇后在棋盤中的位置.
第二步 定義解空間的結構
可以使用8*8的數組,但由于任意兩個皇后都不能在同行,我們可以用數組下標表示
行,數組的值來表示皇后放的列,故可以簡化為一個以維數組x[9]。
第三步 以深度優先的方式搜索解空間,并在搜索過程使用剪枝函數來剪枝
根據條件:x[i] == x[k]判斷處于同一列
abs(k-i) == abs(x[k]-x[i]判斷是否處于同一斜線
我們很容易寫出剪枝函數:
Cpp代碼
  1. bool canPlace( int k){
  2. for ( int i=1;i<k;i++){
  3. //判斷處于同一列或同一斜線
  4. if (x[i]==x[k]||abs(k-i)==abs(x[k]-x[i])) return false ;
  5. }
  6. return true ;
  7. }

然后我們按照回溯框架一,很容易寫出8皇后的回溯代碼:
Cpp代碼
  1. void queen( int i){
  2. if (i>8){
  3. print();
  4. return ;
  5. }
  6. for ( int j=1;j<=8;j++){
  7. x[i]=j; //記錄所放的列
  8. if (canPlace(i))queen(i+1);
  9. }
  10. }

整個代碼:
Cpp代碼
  1. #include<iostream>
  2. #include<cmath>
  3. using namespace std;
  4. int x[9];
  5. void print(){
  6. for ( int i=1;i<=8;i++)
  7. cout<<x[i]<< "" ;
  8. cout<<endl;
  9. }
  10. bool canPlace( int k){
  11. for ( int i=1;i<k;i++){
  12. //判斷處于同一列或同一斜線
  13. if (x[i]==x[k]||abs(k-i)==abs(x[k]-x[i]))
  14. return false ;
  15. }
  16. return true ;
  17. }
  18. void queen( int i){
  19. if (i>8){
  20. print();
  21. return ;
  22. }
  23. for ( int j=1;j<=8;j++){
  24. x[i]=j;
  25. if (canPlace(i))queen(i+1);
  26. }
  27. }
  28. int main(){
  29. queen(1);
  30. return 0;
  31. }

回溯法之二---8皇后問題


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 99在线精品免费视频九九视 | 日本免费一区尤物 | 久久精品免费大片国产大片 | 免费观看日本污污ww网站一区 | 天天插天天干天天射 | 一级黄色片网站 | 香蕉视频网站在线播放 | 亚洲国产成人久久综合一区 | 国产精品久久久久久久久免费观看 | 精品视频日本 | 99欧美在线| 欧美亚洲图区 | 美女撒尿毛片免费看 | 91精品日本久久久久久牛牛 | 久草久草| 亚洲精品久久久久网站 | 久久99热66这里只有精品一 | 国产成人久久精品麻豆二区 | a级毛片毛片免费观看久潮 a级毛片免费 | 综合久久久久久久综合网 | 女人寂寞偷人视频a级 | 国产亚洲漂亮白嫩美女在线 | 久久香蕉国产线看精品 | 国产手机在线国内精品 | 国产精品九九久久精品女同 | 亚洲美女操 | 国产精品九九热 | 99久热re在线精品视频 | 一本久草 | 伊人国产精品 | 精品视频一区在线观看 | 午夜精品九九九九99蜜桃 | 天天躁日日2018躁狠狠躁 | 性做久久 | 日韩成人在线网站 | 亚洲国产精品一区二区久 | 色www精品视频在线观看 | 久久精品国产国产精品四凭 | 国产麻豆免费 | 婷婷综合色| 老司机精品视频个人在观看 |