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

主頁 > 知識庫 > PHP實現圖的鄰接矩陣表示及幾種簡單遍歷算法分析

PHP實現圖的鄰接矩陣表示及幾種簡單遍歷算法分析

熱門標簽:400電話申請辦理 網絡電話400申請 福建高頻外呼防封系統哪家好 商丘外呼系統好處 外呼系統人工客服 周口網絡回撥外呼系統 隨州銷售電銷機器人公司 全國各省地圖標注點 百度地圖標注類型是酒店

本文實例講述了PHP實現圖的鄰接矩陣表示及幾種簡單遍歷算法。分享給大家供大家參考,具體如下:

在web開發中圖這種數據結構的應用比樹要少很多,但在一些業務中也常有出現,下面介紹幾種圖的尋徑算法,并用PHP加以實現.

佛洛依德算法,主要是在頂點集內,按點與點相鄰邊的權重做遍歷,如果兩點不相連則權重無窮大,這樣通過多次遍歷可以得到點到點的最短路徑,邏輯上最好理解,實現也較為簡單,時間復雜度為O(n^3);

迪杰斯特拉算法,OSPF中實現最短路由所用到的經典算法,djisktra算法的本質是貪心算法,不斷的遍歷擴充頂點路徑集合S,一旦發現更短的點到點路徑就替換S中原有的最短路徑,完成所有遍歷后S便是所有頂點的最短路徑集合了.迪杰斯特拉算法的時間復雜度為O(n^2);

克魯斯卡爾算法,在圖內構造最小生成樹,達到圖中所有頂點聯通.從而得到最短路徑.時間復雜度為O(N*logN);

?php
/**
 * PHP 實現圖鄰接矩陣
 */
class MGraph{
  private $vexs; //頂點數組
  private $arc; //邊鄰接矩陣,即二維數組
  private $arcData; //邊的數組信息
  private $direct; //圖的類型(無向或有向)
  private $hasList; //嘗試遍歷時存儲遍歷過的結點
  private $queue; //廣度優先遍歷時存儲孩子結點的隊列,用數組模仿
  private $infinity = 65535;//代表無窮,即兩點無連接,建帶權值的圖時用,本示例不帶權值
  private $primVexs; //prim算法時保存頂點
  private $primArc; //prim算法時保存邊
  private $krus;//kruscal算法時保存邊的信息
  public function MGraph($vexs, $arc, $direct = 0){
    $this->vexs = $vexs;
    $this->arcData = $arc;
    $this->direct = $direct;
    $this->initalizeArc();
    $this->createArc();
  }
  private function initalizeArc(){
    foreach($this->vexs as $value){
      foreach($this->vexs as $cValue){
        $this->arc[$value][$cValue] = ($value == $cValue ? 0 : $this->infinity);
      }
    }
  }
  //創建圖 $direct:0表示無向圖,1表示有向圖
  private function createArc(){
    foreach($this->arcData as $key=>$value){
      $strArr = str_split($key);
      $first = $strArr[0];
      $last = $strArr[1];
      $this->arc[$first][$last] = $value;
      if(!$this->direct){
        $this->arc[$last][$first] = $value;
      }
    }
  }
  //floyd算法
  public function floyd(){
    $path = array();//路徑數組
    $distance = array();//距離數組
    foreach($this->arc as $key=>$value){
      foreach($value as $k=>$v){
        $path[$key][$k] = $k;
        $distance[$key][$k] = $v;
      }
    }
    for($j = 0; $j  count($this->vexs); $j ++){
      for($i = 0; $i  count($this->vexs); $i ++){
        for($k = 0; $k  count($this->vexs); $k ++){
          if($distance[$this->vexs[$i]][$this->vexs[$k]] > $distance[$this->vexs[$i]][$this->vexs[$j]] + $distance[$this->vexs[$j]][$this->vexs[$k]]){
            $path[$this->vexs[$i]][$this->vexs[$k]] = $path[$this->vexs[$i]][$this->vexs[$j]];
            $distance[$this->vexs[$i]][$this->vexs[$k]] = $distance[$this->vexs[$i]][$this->vexs[$j]] + $distance[$this->vexs[$j]][$this->vexs[$k]];
          }
        }
      }
    }
    return array($path, $distance);
  }
  //djikstra算法
  public function dijkstra(){
    $final = array();
    $pre = array();//要查找的結點的前一個結點數組
    $weight = array();//權值和數組
    foreach($this->arc[$this->vexs[0]] as $k=>$v){
      $final[$k] = 0;
      $pre[$k] = $this->vexs[0];
      $weight[$k] = $v;
    }
    $final[$this->vexs[0]] = 1;
    for($i = 0; $i  count($this->vexs); $i ++){
      $key = 0;
      $min = $this->infinity;
      for($j = 1; $j  count($this->vexs); $j ++){
        $temp = $this->vexs[$j];
        if($final[$temp] != 1  $weight[$temp]  $min){
          $key = $temp;
          $min = $weight[$temp];
        }
      }
      $final[$key] = 1;
      for($j = 0; $j  count($this->vexs); $j ++){
        $temp = $this->vexs[$j];
        if($final[$temp] != 1  ($min + $this->arc[$key][$temp])  $weight[$temp]){
          $pre[$temp] = $key;
          $weight[$temp] = $min + $this->arc[$key][$temp];
        }
      }
    }
    return $pre;
  }
  //kruscal算法
  private function kruscal(){
    $this->krus = array();
    foreach($this->vexs as $value){
      $krus[$value] = 0;
    }
    foreach($this->arc as $key=>$value){
      $begin = $this->findRoot($key);
      foreach($value as $k=>$v){
        $end = $this->findRoot($k);
        if($begin != $end){
          $this->krus[$begin] = $end;
        }
      }
    }
  }
  //查找子樹的尾結點
  private function findRoot($node){
    while($this->krus[$node] > 0){
      $node = $this->krus[$node];
    }
    return $node;
  }
  //prim算法,生成最小生成樹
  public function prim(){
    $this->primVexs = array();
    $this->primArc = array($this->vexs[0]=>0);
    for($i = 1; $i  count($this->vexs); $i ++){
      $this->primArc[$this->vexs[$i]] = $this->arc[$this->vexs[0]][$this->vexs[$i]];
      $this->primVexs[$this->vexs[$i]] = $this->vexs[0];
    }
    for($i = 0; $i  count($this->vexs); $i ++){
      $min = $this->infinity;
      $key;
      foreach($this->vexs as $k=>$v){
        if($this->primArc[$v] != 0  $this->primArc[$v]  $min){
          $key = $v;
          $min = $this->primArc[$v];
        }
      }
      $this->primArc[$key] = 0;
      foreach($this->arc[$key] as $k=>$v){
        if($this->primArc[$k] != 0  $v  $this->primArc[$k]){
          $this->primArc[$k] = $v;
          $this->primVexs[$k] = $key;
        }
      }
    }
    return $this->primVexs;
  }
  //一般算法,生成最小生成樹
  public function bst(){
    $this->primVexs = array($this->vexs[0]);
    $this->primArc = array();
    next($this->arc[key($this->arc)]);
    $key = NULL;
    $current = NULL;
    while(count($this->primVexs)  count($this->vexs)){
      foreach($this->primVexs as $value){
        foreach($this->arc[$value] as $k=>$v){
          if(!in_array($k, $this->primVexs)  $v != 0  $v != $this->infinity){
            if($key == NULL || $v  current($current)){
              $key = $k;
              $current = array($value . $k=>$v);
            }
          }
        }
      }
      $this->primVexs[] = $key;
      $this->primArc[key($current)] = current($current);
      $key = NULL;
      $current = NULL;
    }
    return array('vexs'=>$this->primVexs, 'arc'=>$this->primArc);
  }
  //一般遍歷
  public function reserve(){
    $this->hasList = array();
    foreach($this->arc as $key=>$value){
      if(!in_array($key, $this->hasList)){
        $this->hasList[] = $key;
      }
      foreach($value as $k=>$v){
        if($v == 1  !in_array($k, $this->hasList)){
          $this->hasList[] = $k;
        }
      }
    }
    foreach($this->vexs as $v){
      if(!in_array($v, $this->hasList))
        $this->hasList[] = $v;
    }
    return implode($this->hasList);
  }
  //廣度優先遍歷
  public function bfs(){
    $this->hasList = array();
    $this->queue = array();
    foreach($this->arc as $key=>$value){
      if(!in_array($key, $this->hasList)){
        $this->hasList[] = $key;
        $this->queue[] = $value;
        while(!empty($this->queue)){
          $child = array_shift($this->queue);
          foreach($child as $k=>$v){
            if($v == 1  !in_array($k, $this->hasList)){
              $this->hasList[] = $k;
              $this->queue[] = $this->arc[$k];
            }
          }
        }
      }
    }
    return implode($this->hasList);
  }
  //執行深度優先遍歷
  public function excuteDfs($key){
    $this->hasList[] = $key;
    foreach($this->arc[$key] as $k=>$v){
      if($v == 1  !in_array($k, $this->hasList))
        $this->excuteDfs($k);
    }
  }
  //深度優先遍歷
  public function dfs(){
    $this->hasList = array();
    foreach($this->vexs as $key){
      if(!in_array($key, $this->hasList))
        $this->excuteDfs($key);
    }
    return implode($this->hasList);
  }
  //返回圖的二維數組表示
  public function getArc(){
    return $this->arc;
  }
  //返回結點個數
  public function getVexCount(){
    return count($this->vexs);
  }
}
$a = array('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i');
$b = array('ab'=>'10', 'af'=>'11', 'bg'=>'16', 'fg'=>'17', 'bc'=>'18', 'bi'=>'12', 'ci'=>'8', 'cd'=>'22', 'di'=>'21', 'dg'=>'24', 'gh'=>'19', 'dh'=>'16', 'de'=>'20', 'eh'=>'7','fe'=>'26');//鍵為邊,值權值
$test = new MGraph($a, $b);
print_r($test->bst());

運行結果:

Array
(
  [vexs] => Array
    (
      [0] => a
      [1] => b
      [2] => f
      [3] => i
      [4] => c
      [5] => g
      [6] => h
      [7] => e
      [8] => d
    )
  [arc] => Array
    (
      [ab] => 10
      [af] => 11
      [bi] => 12
      [ic] => 8
      [bg] => 16
      [gh] => 19
      [he] => 7
      [hd] => 16
    )
)

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP數據結構與算法教程》、《php程序設計算法總結》、《php字符串(string)用法總結》、《PHP數組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結》及《PHP數學運算技巧總結》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • PHP簡單實現二維數組的矩陣轉置操作示例
  • PHP使用數組實現矩陣數學運算的方法示例
  • PHP實現蛇形矩陣,回環矩陣及數字螺旋矩陣的方法分析
  • PHP 數組和字符串互相轉換實現方法
  • PHP中數組合并的兩種方法及區別介紹
  • PHP遍歷數組的方法匯總
  • PHP遍歷數組的幾種方法
  • php數組函數序列之array_keys() - 獲取數組鍵名
  • php獲取數組中重復數據的兩種方法
  • PHP實現順時針打印矩陣(螺旋矩陣)的方法示例

標簽:南寧 迪慶 定西 十堰 海南 樂山 佛山 六安

巨人網絡通訊聲明:本文標題《PHP實現圖的鄰接矩陣表示及幾種簡單遍歷算法分析》,本文關鍵詞  PHP,實現,圖,的,鄰接,矩陣,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP實現圖的鄰接矩陣表示及幾種簡單遍歷算法分析》相關的同類信息!
  • 本頁收集關于PHP實現圖的鄰接矩陣表示及幾種簡單遍歷算法分析的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产欧美日韩亚州综合 | 伊人夜夜躁av伊人久久| 日韩午夜激情av| 91麻豆精品91久久久久同性| 欧美性生活久久| 欧美日韩精品一区二区天天拍小说 | 国产亚洲精品bt天堂精选| 日韩精品一区二区三区视频在线观看 | 99久久99久久久精品齐齐| 成人久久视频在线观看| 99久久国产免费看| 91激情在线视频| 欧美性色欧美a在线播放| 欧美午夜视频网站| 欧美一二三区在线观看| 337p日本欧洲亚洲大胆色噜噜| 久久中文娱乐网| 中文字幕av在线一区二区三区| 国产精品国产三级国产有无不卡| 亚洲天堂久久久久久久| 午夜精品久久一牛影视| 蜜桃av一区二区| 高清不卡一二三区| 色老汉av一区二区三区| 91精品国产综合久久久蜜臀粉嫩 | 亚洲欧洲制服丝袜| 日韩精品电影在线观看| 国产激情一区二区三区四区| 91免费精品国自产拍在线不卡| 欧美视频一区二| 久久久久9999亚洲精品| 亚洲免费在线视频一区 二区| 三级精品在线观看| 国产成人在线视频网址| 精品视频一区三区九区| 国产日韩精品久久久| 亚洲第一二三四区| 成人午夜碰碰视频| 欧美一级黄色片| 亚洲精品乱码久久久久久久久 | 日韩一区二区三区av| 国产精品日韩成人| 日韩不卡在线观看日韩不卡视频| 国产福利视频一区二区三区| 欧美三电影在线| 国产精品视频看| 男人的天堂亚洲一区| 91丝袜美女网| 日本一区二区三区高清不卡| 免费久久99精品国产| 色婷婷精品大视频在线蜜桃视频 | 亚洲成人自拍偷拍| 99riav久久精品riav| 亚洲国产精品久久一线不卡| 国产精品18久久久久久vr| 91麻豆国产福利精品| 欧美精品一区二区精品网| 午夜欧美在线一二页| 成人av小说网| 久久久91精品国产一区二区三区| 视频在线观看一区二区三区| 91福利视频在线| 最近日韩中文字幕| 成人av免费在线观看| 国产午夜精品美女毛片视频| 美女视频黄久久| 日韩视频免费观看高清完整版| 亚洲精品自拍动漫在线| 在线免费观看视频一区| 一区二区三区美女视频| 在线精品视频一区二区| 亚洲黄色在线视频| 91国偷自产一区二区三区成为亚洲经典 | 国产精品麻豆一区二区| 国产精品伊人色| 久久精品人人做| 国产99精品视频| 国产精品免费看片| www.欧美日韩| 亚洲国产一区在线观看| 欧美三级资源在线| 日韩国产欧美三级| 精品国产凹凸成av人导航| 国产麻豆视频一区二区| 国产精品色婷婷| 欧美在线视频日韩| 日韩av不卡在线观看| 精品国产在天天线2019| 高清在线观看日韩| 亚洲免费成人av| 日韩一区二区麻豆国产| 国产91综合网| 亚洲三级在线免费| 在线播放/欧美激情| 国产一区二区三区四| 中文字幕亚洲综合久久菠萝蜜| 欧美午夜一区二区| 国内精品免费**视频| 亚洲丝袜精品丝袜在线| 欧美浪妇xxxx高跟鞋交| 国内外成人在线视频| 亚洲欧美韩国综合色| 日韩精品中文字幕一区二区三区 | 国产亚洲短视频| 91免费看`日韩一区二区| 日本视频在线一区| 国产精品护士白丝一区av| 69p69国产精品| 9久草视频在线视频精品| 爽爽淫人综合网网站| 综合在线观看色| 欧美第一区第二区| 欧美午夜精品免费| 成人午夜视频网站| 精品夜夜嗨av一区二区三区| 一区二区三区国产豹纹内裤在线| 久久青草欧美一区二区三区| 欧美日韩视频在线观看一区二区三区 | 国产精品久久久久桃色tv| 7777精品久久久大香线蕉| 成人黄色片在线观看| 蜜臀精品久久久久久蜜臀| 亚洲男人的天堂在线aⅴ视频| 久久久久久久综合| 91精品久久久久久久99蜜桃| 日本精品一区二区三区高清| 成人免费视频播放| 国产在线播放一区| 日本sm残虐另类| 图片区小说区国产精品视频| 一区二区成人在线| 国产精品久久久久一区| 欧美国产丝袜视频| 国产欧美日韩中文久久| 久久久久一区二区三区四区| 91精品国产丝袜白色高跟鞋| 欧美日韩大陆一区二区| 在线一区二区三区四区五区| 色婷婷久久久综合中文字幕 | 成人免费一区二区三区在线观看| 奇米在线7777在线精品 | 男男视频亚洲欧美| 一区二区三区日韩欧美精品| 中文字幕精品综合| 欧美国产日韩a欧美在线观看| 精品欧美久久久| 精品久久国产老人久久综合| 欧美一卡在线观看| 欧美v日韩v国产v| 亚洲精品一线二线三线| 337p日本欧洲亚洲大胆色噜噜| 久久久久久久久久久久久女国产乱| 精品国产乱码久久久久久图片 | 中文字幕一区二区三区av| 最新中文字幕一区二区三区| 亚洲欧洲中文日韩久久av乱码| 亚洲色欲色欲www| 亚洲一级电影视频| 蜜臀精品一区二区三区在线观看| 久久精品国产一区二区三区免费看| 麻豆视频观看网址久久| 国产一区二区伦理| 日韩午夜av电影| 91电影在线观看| 在线观看91av| 久久影院电视剧免费观看| 欧美国产欧美亚州国产日韩mv天天看完整| 久久久精品免费免费| 综合分类小说区另类春色亚洲小说欧美| 一区免费观看视频| 午夜久久久久久久久| 久久91精品久久久久久秒播| 成人国产精品免费观看视频| 91国产福利在线| 日韩精品一区二区三区swag| 欧美韩国一区二区| 亚洲自拍偷拍av| 国产一区二区三区av电影| 色综合久久中文综合久久牛| 欧美一区二区三区在线观看| 国产精品女同一区二区三区| 亚洲高清视频中文字幕| 国产成人啪午夜精品网站男同| 欧美三级韩国三级日本一级| 久久奇米777| 日韩成人精品在线观看| 99国产精品99久久久久久| 欧美一二三区在线| 亚洲精选一二三| 丁香婷婷综合五月| 国产高清成人在线| 色综合久久久久| 欧美精品aⅴ在线视频| 337p粉嫩大胆色噜噜噜噜亚洲| 自拍偷拍国产亚洲| 国产精品一线二线三线精华| 欧美精品乱码久久久久久按摩| 国产精品成人免费| 国产剧情一区二区三区| 欧美一区二区三区四区五区|