婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP實現八皇后算法

PHP實現八皇后算法

熱門標簽:七魚外呼系統停用嗎 九江外呼系統 阿里云400電話申請加工單 智能電話機器人排名前十名南京 海南人工外呼系統有效果嗎 抖音有個地圖標注是什么意思 地下城堡2圖九地圖標注 西區企業怎么做地圖標注入駐 保定crm外呼系統運營商

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

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

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

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

詳細說明

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

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

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

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

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

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

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

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種排列

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

您可能感興趣的文章:
  • PHP基于回溯算法解決n皇后問題的方法示例
  • PHP實現基于回溯法求解迷宮問題的方法詳解
  • PHP實現的回溯算法示例
  • PHP 正則表達式效率 貪婪、非貪婪與回溯分析(推薦)
  • PHP回溯法解決0-1背包問題實例分析
  • PHP正則表達式的效率 回溯與固化分組

標簽:韶關 十堰 涼山 昭通 遼陽 九江 甘肅 梅河口

巨人網絡通訊聲明:本文標題《PHP實現八皇后算法》,本文關鍵詞  PHP,實現,八,皇后,算法,PHP,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP實現八皇后算法》相關的同類信息!
  • 本頁收集關于PHP實現八皇后算法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩一区二区三区在线 | 久久精品无码一区二区三区| 午夜国产精品一区| 亚洲香肠在线观看| 91蝌蚪porny成人天涯| 欧美成人性福生活免费看| 久久伊人蜜桃av一区二区| 亚洲一区二区三区四区在线免费观看 | 国产三级精品视频| 免费成人你懂的| 色综合欧美在线| 亚洲老妇xxxxxx| 欧美日韩精品一二三区| 亚洲欧美经典视频| 一本色道久久综合亚洲aⅴ蜜桃 | 日韩视频免费直播| 亚洲一区二区偷拍精品| 国产成人精品免费| 久久亚洲一级片| 国产a视频精品免费观看| 欧美高清在线一区二区| 99精品在线观看视频| 伊人一区二区三区| 欧美一区二区久久| 国产精品夜夜爽| 亚洲欧洲综合另类| 欧美一区二区三区人| 麻豆精品久久精品色综合| 国产精品三级av在线播放| 色94色欧美sute亚洲13| 亚洲国产综合视频在线观看| 欧美人牲a欧美精品| 久久99九九99精品| 一区二区三区高清在线| 日韩视频在线观看一区二区| 国产精品一卡二卡| 同产精品九九九| 亚洲日本在线观看| 欧美日韩亚洲不卡| 亚洲女子a中天字幕| 91精品国产91热久久久做人人| 国产乱人伦偷精品视频不卡| 久久精品无码一区二区三区| 欧美三级乱人伦电影| 国产精华液一区二区三区| 亚洲国产成人tv| 一区二区三区四区在线| 久久综合精品国产一区二区三区| 欧美日韩午夜在线视频| 国产激情视频一区二区三区欧美| 亚洲一区二区三区激情| 国产精品国产三级国产有无不卡| 精品久久一区二区三区| 在线观看国产一区二区| 成人免费看黄yyy456| 日本成人在线电影网| 久久精品久久99精品久久| 日韩国产高清在线| 一区二区三区日韩在线观看| 国产精品久久久久一区二区三区| 日韩欧美美女一区二区三区| 精品日韩欧美在线| 日韩欧美国产一区二区三区| 日韩欧美一区在线| 欧美精品一区二区高清在线观看| 欧美大片免费久久精品三p | 成人动漫一区二区三区| 麻豆国产精品一区二区三区 | 日本韩国欧美一区| 日韩午夜激情视频| 欧美tickling挠脚心丨vk| 中文字幕一区二区三区在线观看 | 国产一区二区成人久久免费影院| 国产不卡在线一区| 日韩一区二区三区视频| 成人欧美一区二区三区小说| 一区二区三区加勒比av| 久久精品国产**网站演员| 亚洲激情图片qvod| 国产成人在线看| 制服丝袜日韩国产| 亚洲综合视频在线观看| 国产精品18久久久久| 欧美一区二区二区| 亚洲国产综合视频在线观看| 亚洲国产高清在线观看视频| 国产亚洲欧美色| 日本大胆欧美人术艺术动态| 国产精品久久久久永久免费观看 | 国产综合一区二区| 久久久亚洲精品一区二区三区| 久久精品视频在线免费观看| 日韩av不卡一区二区| 欧美精品日韩综合在线| 亚洲福利国产精品| 91九色最新地址| 亚洲福利一二三区| 欧美日韩一区久久| 天天亚洲美女在线视频| 欧美日韩精品电影| 蜜桃久久av一区| 欧美精品一区二区三| 懂色av一区二区在线播放| 国产精品无圣光一区二区| 97精品国产97久久久久久久久久久久| 国产精品毛片高清在线完整版| 99久久国产综合色|国产精品| 亚洲日本成人在线观看| 91精品国产日韩91久久久久久| 久久精品国产99久久6| 国产欧美一区二区精品性| 一本久久综合亚洲鲁鲁五月天| 日韩福利电影在线观看| 国产精品国产三级国产| 最新高清无码专区| 精品免费视频一区二区| 91玉足脚交白嫩脚丫在线播放| 老司机精品视频一区二区三区| 亚洲少妇30p| 国产精品蜜臀av| 26uuu另类欧美| 欧美一区二区人人喊爽| 91视频91自| 色婷婷综合五月| 懂色av噜噜一区二区三区av| 精品午夜一区二区三区在线观看| 国产精品国产三级国产有无不卡| 欧美日韩成人在线一区| 欧美亚洲一区三区| 91麻豆成人久久精品二区三区| 国产成人午夜视频| 成人性生交大合| 成人黄色电影在线 | 久久九九久久九九| 久久久电影一区二区三区| 国产日韩欧美精品综合| 欧美极品另类videosde| 亚洲欧美另类久久久精品2019| 国产精品视频免费| 1区2区3区欧美| 亚洲在线中文字幕| 性欧美疯狂xxxxbbbb| 日韩成人一区二区三区在线观看| 亚洲激情在线播放| 一区二区三区精密机械公司| 国产精品成人午夜| 久久精品国产澳门| 91视频.com| 欧美一区二区三区免费在线看| 成人v精品蜜桃久久一区| 色欲综合视频天天天| 日韩视频一区在线观看| 一区二区日韩av| av福利精品导航| 久久影院电视剧免费观看| 亚洲mv在线观看| 欧美一区二区三区在线电影| 91麻豆精东视频| 国产精品丝袜一区| 国产一区在线精品| 精品国产乱码久久久久久影片| 亚洲免费在线电影| 国产精品久久久久久久久免费相片 | 亚洲国产成人一区二区三区| 婷婷国产在线综合| 欧美视频精品在线观看| 中文字幕中文在线不卡住| 国产精品亚洲专一区二区三区| 日韩精品一区二区在线观看| 樱桃视频在线观看一区| 在线免费观看日本欧美| 国产精品成人免费在线| 91成人在线精品| 午夜成人在线视频| 欧美一区二区三区在线观看| 亚洲一卡二卡三卡四卡| 91精品国产色综合久久ai换脸| 免费视频一区二区| 国产精品你懂的在线欣赏| 色狠狠一区二区| 久久成人免费电影| 中文字幕欧美三区| 欧美老女人第四色| 久久精品国产久精国产爱| 国产精品久久久久久久久果冻传媒 | 欧美又粗又大又爽| 精品一二线国产| 国产精品美女久久久久久久久久久 | 日韩欧美一区二区免费| 国产精品福利在线播放| 老司机精品视频一区二区三区| 在线不卡一区二区| 伊人色综合久久天天| 高清不卡一区二区| 久久精品亚洲麻豆av一区二区| 午夜视频久久久久久| 精品一区二区三区在线播放视频| 3751色影院一区二区三区| 亚洲影院久久精品| 欧美乱妇20p|