遞迴演算法應用例項 八皇后演算法

2021-10-12 12:26:47 字數 1598 閱讀 5073

回溯演算法的經典案例

回溯演算法的典型案例。該問題是國際西洋棋棋手馬克斯.貝瑟爾於2023年提出:在8x8格的西洋棋上擺放八個皇后,使其不能互相攻擊,即:任意兩個皇后都不能外乾同一行、同一列或同一斜線上,問有多少種擺法。

思路分析

第乙個皇后先放在第一行第一列

第二個皇后放在第二行第一列、然後判斷是否0k,如果不ok, 繼續放在第二列、第三列、依次把所有列都放完,找到乙個合適

繼續第三個皇后,還暈第一列、第二列…直到第8個皇后也能放在乙個不衝突的位置,算是找到了乙個正確解

當得到乙個正確解時,在棧回退到上乙個棧時,就會開始回溯,即將第乙個皇后,放到第一列的所有正確解,全部得到

然後回頭繼續第-乙個皇后放第二列,後面繼續迴圈執行1,2,3的步驟

**說明:**理論上應該建立乙個二維陣列來表示棋盤,但是實際上可以通過演算法用乙個一維陣列即可解決問題. arr[8]=表示乙個正解

對應arr下標表示第幾行,即第幾個皇后,arr[i]=val , val表示第i+1個皇后,放在第i+1行的第val+1列

效率可能比較低,後面也有演算法對其進行優化,比如貪心演算法等,後面的筆記會提到

**

package com.wang.recursion;

/** * @author 王慶華

* @version 1.0

* @date 2020/12/20 19:45

* @description todo

* @pojectname 八皇后問題

*/public

class

queue8

int[

] array =

newint

[max]

;static

int count =0;

public

static

void

main

(string[

] args)

//編寫乙個方法,放置第n個皇后

//特別注意:check是每一層遞迴時,進入到check都有for迴圈,因此會有回溯

private

void

check

(int n)

//沒有放完的話,依次放入皇后,判斷是否衝突

for(

int i =

0; i < max ; i++

)//如果衝突,就繼續執行array[n] = i;這個時候i已經++了,就是放到了下一列}}

/** //檢視當我們放置第n個皇后時,就去檢測該皇后是否和前面已經擺好的皇后衝突

* @param n 表示第n個皇后

* @return

*/private

boolean

judge

(int n)

}return

true;}

//將皇后拜訪的位置列印出來

private

void

print()

system.out.

println()

;}}

八皇后 遞迴演算法

在8 8格的西洋棋上擺放8個皇后,使其不能互相攻擊,即任意兩個皇后都不能處於同一行 同一列或同一斜線上,問有多少種擺法。高斯認為有76種方案。1854年在柏林的象棋雜誌上不同的作者發表了40種不同的解,後來有人用圖論的方法解出92種結果。如果經過 90度 180度旋轉,和對角線對稱變換的擺法看成一類...

八皇后遞迴演算法

include 規則 在8x8的棋盤內放置八個皇后,並且保證每個皇后是安全的。分析 每個皇后必須單獨一行,用乙個陣列來表示她們所在列的位置,下標代表所在行的位置。int aqueen 8 儲存結果 bool analyzepoint int x,int y 規則檢測,檢測當前位置是否和已有位置衝突 ...

遞迴演算法之八皇后

八皇后問題核心 1 同一行或者同一列不能放置皇后 2 斜率為1 1的對角線上不能有兩個皇后。如圖 實現原理 include include using std cout using std endl int count 0 int detection int board 8 int line,int...