午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > 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實現八皇后算法的相關信息資訊供網民參考!
  • 推薦文章
    99这里有精品视频| 亚洲开发第一视频在线播放| 麻豆成人免费视频| 日韩成人在线网站| 中文字幕日韩综合| 中文字幕成人网| 久久久久久九九| 内射后入在线观看一区| 久久久久久久久久久久av| 国产波霸爆乳一区二区| 日韩欧美在线网站| 国产伦理在线观看| 丁香五六月婷婷久久激情| 国产在线xxxx| 久久综合九色综合97婷婷| 久久精品ww人人做人人爽| 韩国av电影在线观看| 91精品国产色综合| 五月天婷婷激情| 中文字幕在线国产精品| 国产大屁股喷水视频在线观看| www.99re7| 国产成人在线观看| 国产精品自产自拍| av免费看网址| 日本精品免费观看高清观看| 91久色国产| 成人网在线免费视频| 97人妻天天摸天天爽天天| 国产精品免费久久久| 精品在线免费视频| 99久久99| 国产午夜精品久久久久久久 | 日韩不卡在线观看| 日韩欧美一区二区三区四区五区| 欧美性猛交xxxx乱大交hd| 欧美伊人久久大香线蕉综合69| 自拍偷拍色综合| 日本福利一区二区三区| 国产精品九色蝌蚪自拍| 白丝女仆被免费网站| 三区精品视频观看| 97人人模人人爽人人少妇| 成人美女视频在线看| 国产精品视频免费播放| 亚洲国产日韩综合一区| 欧美一区二区三区色| 欧美性猛交bbbbb精品| 91福利视频导航| 日韩欧美一区二区在线| 无码精品a∨在线观看中文| 色综合久久综合| 风流少妇一区二区| 五月天综合激情| 日韩国产精品毛片| 亚洲第一页中文字幕| 国产精品三级一区二区| 欧美成人video| 国产精品国产高清国产| 成人观看免费视频| 91人妻一区二区| caoporn超碰97| 精品一区二区不卡| 久久激情视频久久| 久久这里都是精品| 91性高潮久久久久久久| 久久精品人人做人人爽| 日本一区二区三级电影在线观看| 天天摸天天碰天天添| 欧美熟乱第一页| 亚洲国产成人在线观看| 国产精品一级二级| 被黑人猛躁10次高潮视频| 欧美在线www| 成人欧美一区二区三区在线播放| 高潮一区二区三区| 就去色蜜桃综合| 久久伊人色综合| 中文字幕第4页| 一夜七次郎国产精品亚洲| 精品国产一区二区三区四| 国产成人精品免高潮在线观看| 久久精品主播| 亚洲一卡二卡三卡| 亚洲一区中文日韩| 亚洲一区二区自偷自拍 | 一本加勒比波多野结衣| 一个人看的www久久| 国产丝袜视频在线观看| 久久久影院一区二区三区| 国产日韩精品一区| 国产chinesehd精品露脸| 一本一本久久a久久精品牛牛影视| 在线观看毛片视频| 欧美精品一区在线发布| 夜夜操天天操亚洲| 欧洲美熟女乱又伦| 97精品视频在线| 国精产品一区一区三区mba视频| 国产午夜福利在线播放| 日韩一级片网址| 中文字幕免费在线看| 鲁片一区二区三区| 五月激情综合网| 久草网在线观看| 亚洲va久久久噜噜噜| 亚洲天堂av一区| 五月天精品在线| 国产女同一区二区| 中文一区在线播放| 1024手机在线观看你懂的| 国产高清在线不卡| 国产色一区二区| 免费看毛片的网站| 欧美一级视频一区二区| 91美女片黄在线观看91美女| 午夜不卡久久精品无码免费| 欧美激情亚洲激情| 成人av在线网| 亚洲一区二区乱码| 国产成人精品综合| 国产精品久久久久影院老司| 欧美成人短视频| 成人免费直播live| 一区二区成人在线观看| 久久午夜鲁丝片午夜精品| 国产九色91| 日韩欧美福利视频| 中文字幕一区二区人妻| 欧美一级特黄aaaaaa在线看片| 日韩欧美一级二级| 欧美自拍偷拍第一页| 老熟妇仑乱视频一区二区| 日韩中文娱乐网| caoporm超碰国产精品| 中文字幕 日本| 国产精品日日做人人爱| 亚洲激情自拍偷拍| 国产精品久久久久久久久久久久久久久久久 | 日本丰满少妇裸体自慰| 国产精品成人av性教育| 亚洲人成亚洲人成在线观看图片| 久久久久久久久久久97| 亚洲激情一区二区| 日韩国产欧美区| 国产在线精品一区二区| 国产一级二级在线观看| 91精品视频在线看| 色视频一区二区| 亚洲av无码乱码国产精品| 天天干在线影院| 欧美诱惑福利视频| 亚洲一区在线观看免费| 亚洲精品国产精品乱码视色| 国产h视频在线播放| 欧美成人合集magnet| 日本一区二区三区dvd视频在线| 成熟的女同志hd| 在线播放豆国产99亚洲| 一区二区三区四区在线观看视频| 丁香婷婷综合色啪| 免费看一级黄色| 日本在线观看一区| 精品偷拍各种wc美女嘘嘘| 国产黑丝在线一区二区三区| 影音先锋男人看片资源| 午夜精品一区二区在线观看 | 自拍偷拍亚洲欧美| 久久蜜桃一区二区| 69成人免费视频| av网站在线观看不卡| 欧美做受高潮1| 在线国产电影不卡| 精品一区二区影视| 国产免费久久久久| av在线com| 欧美极品第一页| 午夜精品一区在线观看| 少妇喷水在线观看| 中文字字幕码一二三区| 欧美综合激情| 久久精品免费电影| 亚洲已满18点击进入久久| 国产三级午夜理伦三级| 黄色av电影网站| 欧洲久久久久久| 久久综合色88| 欧美日韩亚洲精品内裤| 美国三级日本三级久久99| 日本少妇aaa| 男人天堂av片| 国产精品第8页| 欧美www视频| 久久精品视频免费| 亚洲无码精品在线播放| 精品人妻一区二区乱码| 欧美日韩精品免费观看| 久久这里有精品| 色国产精品一区在线观看| 国产麻豆成人精品| 久久久精品视频网站| 肉色超薄丝袜脚交| 欧美日本韩国在线| 欧美精品精品精品精品免费| 黑人与娇小精品av专区| 国产在线不卡一区| 亚洲欧美一区二区三区在线观看| 日韩在线不卡一区| 欧美一区二区三区在线播放 | 免费在线黄色网| 蜜臀av免费观看| 欧美伦理一区二区| 欧洲日韩成人av| 亚洲第一中文字幕在线观看| 亚洲女同ⅹxx女同tv| 美女精品一区二区| 无码任你躁久久久久久久| 国产黄色三级网站| 青春草国产视频| 国产精品久久久久久久久久久久冷| 最近2019年中文视频免费在线观看 | 日韩精品免费在线播放| 一二三四社区欧美黄| 国产一区福利在线| 国产精品免费无遮挡| 男人晚上看的视频| 亚洲制服在线观看| 亚洲精品一区二区三| 国产精品三级美女白浆呻吟| 在线观看国产成人av片| 欧美日韩国产成人在线免费| 国产精品福利av| 国产伦精品一区二区三区在线观看| 中文字幕在线视频第一页| 最新黄色av网址| 国产高清av片| 俄罗斯av网站| 欧美亚洲免费在线| 国产精品96久久久久久又黄又硬| 在线观看亚洲区| 日韩一区二区在线免费观看| 亚洲男人天堂av| 99久久久国产精品免费蜜臀| 蜜乳av另类精品一区二区| 日韩精品一区二区亚洲av| 欧美 日韩 国产 成人 在线观看 | 在线一区二区日韩| 欧美精品一级二级| 亚洲黄色小视频| 91免费精品国自产拍在线不卡| 久久伊人亚洲| 国产露脸国语对白在线| 欧美三级一区二区三区| 精品在线观看一区| 中文字幕在线播放视频| 国模私拍视频在线观看| 福利视频一二区| 一级二级三级欧美| 老牛影视免费一区二区| 亚洲伊人成综合成人网| 日韩av理论片| 欧美激情在线视频二区| 日韩在线视频观看| 亚洲欧美精品在线| 欧美va亚洲va| 在线不卡一区二区| 欧美在线影院一区二区| 欧美日韩久久久久| 亚洲一本大道在线| 国产精品蜜臀在线观看| 2020国产精品自拍| 成人妖精视频yjsp地址| 国产一区二区剧情av在线| 免费在线看一区| 视频在线观看国产精品| 成人羞羞国产免费图片| 黄色小视频免费在线观看| 97精品人妻一区二区三区香蕉| 国产性生活视频| 亚洲精品国产精品乱码| 久久夜靖品2区| 日韩精品久久久久久久酒店| 国产无遮挡aaa片爽爽| 欧美人妻一区二区| 久久国产在线视频| 欧美特级一级片| 久久婷婷国产麻豆91| 国产午夜福利一区二区| 国产精品a成v人在线播放| 欧美毛片在线观看| 国产精品白浆一区二小说| 五月天婷婷丁香| 亚洲视频免费播放| 天天干天天操天天操| 国产九色91回来了| 国产日本精品视频| 蜜桃视频在线观看www| 亚洲欧美日本在线观看| 丝袜美腿成人在线| 九九精品视频在线看| 国产大陆a不卡| 2020国产精品自拍| 综合久久给合久久狠狠狠97色| 玉米视频成人免费看| 色综合天天综合色综合av | 激情内射人妻1区2区3区| 亚洲欧美另类动漫| 国产大学生av| 熟女少妇一区二区三区| 国产在线观看免费视频软件| 中文字幕影音先锋| 黄色av网站免费| 国产男女猛烈无遮挡| 久久久久久一区二区| 国产一区二区精品久久91| 91丨九色丨蝌蚪富婆spa| 国产精品久久三| 黄色成人av在线| 91精品国产品国语在线不卡| 日韩av影视综合网| 免费99精品国产自在在线| 日本精品久久久久影院| 91色视频在线导航| 日本成人三级电影网站| bt天堂新版中文在线地址| 日韩av手机版| 男女黄床上色视频| 久久精品一区二区三| 精人妻无码一区二区三区| 亚洲黄色精品视频| 国产成人日日夜夜| 亚洲欧洲综合另类| 色狠狠一区二区三区香蕉| 日韩欧美国产系列| 久久精品国产96久久久香蕉| 国产成人拍精品视频午夜网站| 99久久伊人精品影院| 中文字幕一区二区三区最新| 免费看国产黄色片| 男人舔女人下部高潮全视频| 久久夜靖品2区| 天堂在线资源库| 2020国产成人综合网| 欧美日韩亚洲精品内裤| 亚洲码在线观看| 国产精品pans私拍| 亚洲免费在线精品一区| 九色在线视频观看| 亚洲蜜桃精久久久久久久久久久久| 久久精品www| 久久久水蜜桃av免费网站| 久久久久99精品国产片| 色菇凉天天综合网| 日韩天堂在线视频| 91久久精品一区二区别| 成人在线国产视频| 国产十八熟妇av成人一区| 日韩欧美亚洲视频| 日韩**一区毛片| 亚洲人成亚洲人成在线观看图片| 日韩女优制服丝袜电影| 国产69久久精品成人| 视频一区免费观看| 久久发布国产伦子伦精品| 久久婷婷综合国产| 麻豆成人91精品二区三区| 亚洲精品视频自拍| 日韩激情av在线免费观看| 国产精品老牛影院在线观看| 18视频在线观看娇喘| 日本护士做爰视频| 凹凸精品一区二区三区| 国产大片一区二区| 欧美亚洲一区二区在线观看| 久久综合伊人77777| 久久国产一区二区| 热久久久久久久久| 成人免费看片98欧美| 国产高清不卡二三区| 色8久久人人97超碰香蕉987| 久久久国产精品视频| 欧美日韩国产精品一卡| 免费在线观看日韩av| 伊人网综合在线| 久久先锋影音av鲁色资源网| 日韩一区二区三区三四区视频在线观看| 欧美激情三级免费| 宅男av一区二区三区| 日韩人妻无码精品综合区| 老牛影视av牛牛影视av| 亚洲三级电影网站| 国产一区二区三区日韩欧美| 黄色国产精品一区二区三区| 天天爽夜夜爽一区二区三区| 亚洲另类欧美日韩| 成人小视频免费观看| 欧美一级理论片| 91在线精品视频| 精品亚洲视频在线| 91丨porny丨在线中文| 国产欧美精品日韩区二区麻豆天美| 亚洲成成品网站| 高清av免费一区中文字幕| 香蕉视频xxx| 亚洲精品97久久中文字幕| 亚洲成人激情av| 热re99久久精品国产66热| 欧美牲交a欧美牲交aⅴ免费下载| 一级成人黄色片| 国产精品免费视频一区|