老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

使用PHP怎么實現一個八皇后算法-創新互聯

使用PHP怎么實現一個八皇后算法?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

專注于為中小企業提供網站建設、成都做網站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業安福免費做網站提供優質的服務。我們立足成都,凝聚了一批互聯網行業人才,有力地推動了上千企業的穩健成長,幫助中小企業通過網站建設實現規模擴充和轉變。

PHP代碼實現:


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怎么實現一個八皇后算法的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創新互聯行業資訊頻道,感謝各位的閱讀!


分享名稱:使用PHP怎么實現一個八皇后算法-創新互聯
鏈接URL:http://www.xueling.net.cn/article/shoii.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 人妻少妇久久中文字幕 | 免费国产日韩欧美 | 在线超碰| 午夜久久精品 | 大内密探零零性在线 | 精品一区二区三区波多野结衣 | 综合热久久 | av在线在线 | 性色AⅤ在线观看免费 | 草逼一级片 | 俄罗斯老熟妇乱子伦视频 | 免费人妻无码不卡中文字幕系列 | 情侣做性视频在线播放 | 初高中生免费视频毛片 | 免费av网站在线观看 | 亚洲日韩欧美一区久久久久我 | 国产乱子伦一区二区三区视频播放 | 91视频分类 | 被黑人粗黑大肉奉视频 | 在线资源观看 | 国产v日产∨综合v精品视频 | 在线播放一区 | 国产在线观看高清视频黄网 | 久艹在线| 中国女人一级片 | 2002亚洲精品真实在线 | 亚洲国产欧美自拍 | 羞羞答答xxdd.tv | 免费一级黄色大片 | 91茄子视频在线观看 | 亚洲中文字幕乱伦 | 少妇久久久久久人妻无码 | 精品久久亚洲精品中文字幕 | 三级影院在线观看 | 精品人人妻人人澡人人爽牛牛 | 18欧美乱大交 | 日本岛国片在线观看一区二区 | 午夜av影院 | 91精品国模一区二区三区 | 天天爱夜夜操 | 国产亚洲欧美精品在线 |