亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

PHP實現八皇后算法

2024-05-05 00:08:46
字體:
來源:轉載
供稿:網友

回溯算法實際上一個類似枚舉的搜索嘗試過程,主要是在搜索嘗試過程中尋找問題的解,當發現已不滿足求解條件時,就“回溯”返回,嘗試別的路徑?;厮莘ㄊ且环N選優搜索法,按選優條件向前搜索,以達到目標。但當探索到某一步時,發現原先選擇并不優或達不到目標,就退回一步重新選擇,這種走不通就退回再走的技術為回溯法,而滿足回溯條件的某個狀態的點稱為“回溯點”。

回溯算法的基本思想是:從一條路往前走,能進則進,不能進則退回來,換一條路再試。

八皇后問題,是一個古老而著名的問題,是回溯算法的典型案例。該問題是國際西洋棋棋手馬克斯·貝瑟爾于1848年提出:在8×8格的國際象棋上擺放八個皇后,使其不能互相攻擊,即任意兩個皇后都不能處于同一行、同一列或同一斜線上,問有多少種擺法。

這邊先以4皇后來解釋解決步驟:

詳細說明

在第一行有四種可能,選擇第一個位置放上皇后

PHP,八皇后算法

第二行原本可以有四種可能擺放,但是第一第二個已經和第一行的皇后沖突了,因此只剩下第三第四個格子了,先選擇第三個格子

PHP,八皇后算法

接下來是第三行,根據規則可以看出,第三行已經沒有位置放了,因為都跟第一第二行的皇后沖突,此時返回到第二行第四個

PHP,八皇后算法

繼續來到第三行,發現只有第二個滿足條件

PHP,八皇后算法

然后發現第四行已經不能放了,只能繼續返回,返回到第一行,開始下一種可能

PHP,八皇后算法

按照 1-5 的步驟,可以找到下面的其中一種解法

PHP,八皇后算法

總而言之,回溯法就是開始一路到底,碰到南墻了就返回走另外一條路,有點像窮舉法那樣走遍所有的路。

PHP代碼實現:

<?php class Backtracking {  protected $chessboard;  // 棋盤 二維數組 表示坐標軸 protected $N;      // N表示幾皇后 protected $has_set_x;  // 已經設置的x坐標數組 已經設置的x坐標就不能重復了,用于檢查坐標是否可用 protected $has_set_y;  // 已經設置的y坐標數組 已經設置的y坐標就不能重復了,用于檢查坐標是否可用 protected $has_set_site; // 已經設置的點  function __construct($N) { // 初始化數據 $this->N = $N; $this->chessboard = array(); for ($i=0; $i < $N; $i++) {   for ($j=0; $j < $N; $j++) {   $this->chessboard[$i][$j] = 0;  } } $this->has_set_x = array(); $this->has_set_y = array(); $this->has_set_site = array(); }  // 獲取排列 public function getPermutation($is_get_on = true) { // is_get_on 是否獲取一種排列 true:是 false:獲取所有排列 $current_n = 0; // 當前設置第幾個皇后 $start_x = 0;  // 當前的x坐標 從x開始放置嘗試 $permutation_array = array(); // 全部皇后放置成功的排列數組 while ($current_n < $this->N && $current_n >= 0) {  $site_result = $this->setQueenSite($current_n, $start_x); // 設置皇后位置  if($site_result == true && $current_n + 1 >= $this->N) { // 如果最后的皇后位置放置成功則記錄信息  $permutation_array[] = array_merge($this->has_set_site, array(array('x' => $site_result['x'], 'y' => $site_result['y'])));  if($is_get_on == false) { // 如果是獲取所有排列,則設置當前放置失敗,讓程序回溯繼續找到其他排列   $site_result = false;  }  }  if($site_result == true) {  $this->chessboard[$site_result['x']][$site_result['y']] = 1;  $this->has_set_x[] = $site_result['x'];  $this->has_set_y[] = $site_result['y'];  $this->has_set_site[] = array('x' => $site_result['x'], 'y' => $site_result['y']);  $current_n++; // 皇后位置放置成功,繼續設置下一個皇后,重置下一個皇后的x坐標從0開始  $start_x = 0;  }else {  // 當前皇后找不到放置的位置,則需要回溯到上一步  $previous_site = array_pop($this->has_set_site); // 找到上一步皇后的位置  if(!empty($previous_site)) {   $start_x = $previous_site['x'] + 1; // 讓上一步的皇后的x坐標+1繼續嘗試放置   $this->deleteArrayValue($this->has_set_x, $previous_site['x']);   $this->deleteArrayValue($this->has_set_y, $previous_site['y']);   $this->chessboard[$previous_site['x']][$previous_site['y']] = 0;  }  $current_n--; // 回溯到上一步,即讓一個皇后x坐標+1繼續嘗試放置  } } return $permutation_array; }  // 設置皇后位置 public function setQueenSite($n, $start_x) { $start_y = $n; if($start_x >= $this->N) return false; $check_result = $this->checkQueenSite($start_x, $start_y); // 檢查當前是否可放置 if($check_result == true) {  return array('x' => $start_x, 'y' => $start_y); }else { // 不可放置,則x坐標+1,繼續嘗試  $start_x++;  return $this->setQueenSite($n, $start_x); } }  // 檢查皇后位置是否正確 public function checkQueenSite($x, $y) { // 判斷當前坐標的橫、縱、斜線是否存在已經放置的皇后 if(in_array($x, $this->has_set_x)) return false; if(in_array($y, $this->has_set_y)) return false; $operate_array = array(  array('operate_x' => '+', 'operate_y' => '+'),  array('operate_x' => '-', 'operate_y' => '-'),  array('operate_x' => '+', 'operate_y' => '-'),  array('operate_x' => '-', 'operate_y' => '+') ); foreach ($operate_array as $key => $value) {  $diagonal_x = $x;  $diagonal_y = $y;  while (true) {  eval("/$diagonal_x=$diagonal_x {$value['operate_x']} 1;");  eval("/$diagonal_y=$diagonal_y {$value['operate_y']} 1;");  if($diagonal_x >= $this->N || $diagonal_y >= $this->N || $diagonal_x < 0 || $diagonal_y < 0) break;  if($this->chessboard[$diagonal_x][$diagonal_y] == 1) return false;  } } return true; }  // 刪除數組元素 public function deleteArrayValue(&$array, $value) { $delete_key = array_search($value, $array); array_splice($array, $delete_key, 1); } } $N = 8; // 8表示獲取8皇后的排列組合$backtracking = new Backtracking($N);$permutations = $backtracking->getPermutation(false);var_dump($permutations); // 輸出92種排列

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久色| 3344国产精品免费看| 日韩精品在线观看网站| 欧美视频国产精品| 欧美激情性做爰免费视频| 伊人久久久久久久久久久| 92国产精品视频| 超碰97人人做人人爱少妇| 久久久久久久久91| 欧美综合国产精品久久丁香| 亚洲第一免费网站| 亚洲第一网中文字幕| 欧美日韩成人黄色| 日本精品视频在线播放| 国产精品视频资源| 亚洲欧美国产另类| 欧美性猛交xxxx乱大交| 国产精品久久一区主播| 亚洲美女av电影| 亚洲成人教育av| 亚洲精品动漫久久久久| 中国人与牲禽动交精品| 欧美丝袜第一区| 欧美激情伊人电影| 欧美乱大交做爰xxxⅹ性3| 国产精品狠色婷| 成人精品福利视频| 国产日韩精品在线| 超碰97人人做人人爱少妇| 91在线无精精品一区二区| 欧美一级高清免费| 日韩av在线免播放器| 88国产精品欧美一区二区三区| 九九九久久久久久| 欧美激情在线有限公司| 精品亚洲国产视频| 欧美黄色成人网| 亚洲free性xxxx护士hd| 91精品久久久久久久| 91成人在线播放| 国产成+人+综合+亚洲欧洲| 欧美日韩国产麻豆| 亚洲欧美国产精品va在线观看| 国产精品99久久久久久人| 精品国产老师黑色丝袜高跟鞋| 91成人免费观看网站| 国产精品福利在线观看| 欧美日韩一区二区免费视频| 永久免费看mv网站入口亚洲| 国产亚洲欧洲高清一区| 日本亚洲欧美三级| 美女999久久久精品视频| 国产亚洲欧美一区| 国产偷亚洲偷欧美偷精品| www.久久草.com| 亚洲人成电影网站| 欧美日韩999| 丁香五六月婷婷久久激情| 一本色道久久综合狠狠躁篇怎么玩| 美女视频久久黄| 午夜精品蜜臀一区二区三区免费| 国产精品色视频| 欧美精品电影在线| 亚洲第一区第二区| 欧美亚洲激情在线| 韩国v欧美v日本v亚洲| 久久伊人91精品综合网站| 成人中文字幕在线观看| 亚洲欧美激情另类校园| 国产成人综合久久| 免费99精品国产自在在线| 美女av一区二区| 亚洲成人免费网站| 成人午夜黄色影院| 精品福利樱桃av导航| 中文字幕亚洲综合| 久久久精品一区二区三区| 日韩一级黄色av| 日韩视频在线免费| 欧美日韩一区二区免费在线观看| 精品小视频在线| 欧美久久精品午夜青青大伊人| 亚洲激情在线观看视频免费| 91沈先生在线观看| 中文字幕一区电影| 国产精品久久久久久久久久三级| 久久综合久久八八| 国内成人精品视频| 国产精品爽爽爽爽爽爽在线观看| 亚洲成年人在线| 国产精品欧美激情在线播放| 午夜免费在线观看精品视频| 九九视频这里只有精品| 视频一区视频二区国产精品| 亚洲国产欧美久久| 亚洲午夜精品视频| 91av视频在线免费观看| 国产视频久久久久久久| 欧美尺度大的性做爰视频| 国产精品r级在线| 欧美精品www| 中文字幕一区电影| 久久99久久99精品免观看粉嫩| 欧美性xxxx极品高清hd直播| www.日韩欧美| 午夜精品一区二区三区在线视| 国产精品成人品| 性欧美长视频免费观看不卡| 97超碰蝌蚪网人人做人人爽| 日本欧美一级片| 韩剧1988免费观看全集| 伦理中文字幕亚洲| 国产精品亚洲片夜色在线| 欧美成人黑人xx视频免费观看| 日韩亚洲欧美中文在线| 国产一区二区三区在线视频| 在线视频精品一| 午夜伦理精品一区| 亚洲欧美精品一区二区| 成人免费观看49www在线观看| 久久久亚洲影院你懂的| 日韩有码在线观看| 亚洲九九九在线观看| 欧美午夜宅男影院在线观看| 欧美大片在线影院| 欧美一区二区三区免费视| 欧美成人激情视频免费观看| 久久久久久久成人| 亚洲自拍小视频| 国产精品国产亚洲伊人久久| 日韩精品极品毛片系列视频| 精品亚洲aⅴ在线观看| 91在线高清免费观看| 亚洲国产精品嫩草影院久久| 国产精品久久久久av| 欧美视频在线观看免费| 久久精品国产v日韩v亚洲| 亚洲最大在线视频| 久久频这里精品99香蕉| 国产美女久久久| 国模极品一区二区三区| 久久精品国产视频| 国产精品一区av| 欧美在线一区二区视频| 欧美在线激情视频| 欧美老少做受xxxx高潮| 欧洲美女7788成人免费视频| 久久久精品久久| 亚洲欧洲日产国码av系列天堂| 国产99久久精品一区二区永久免费| 久久综合久中文字幕青草| 欧美午夜激情在线| 亚洲欧美日韩一区二区三区在线| 国产精品久久久久av免费| 欧美性猛交xxxx乱大交蜜桃| 国语自产精品视频在免费| 91久久久久久久一区二区| 欧美成年人网站| 欧美成人h版在线观看| 在线观看国产欧美| 国产亚洲精品综合一区91| 992tv成人免费视频| 亚洲国产美女精品久久久久∴| 欧美日韩成人免费|