欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP實現(xiàn)克魯斯卡爾算法實例解析

 更新時間:2014年08月22日 11:49:00   投稿:shichen2014  
這篇文章主要介紹了PHP實現(xiàn)克魯斯卡爾算法實例解析,是PHP程序設(shè)計中一個比較經(jīng)典的應(yīng)用,需要的朋友可以參考下

本文實例展示了PHP實現(xiàn)的格魯斯卡爾算法(kruscal)的實現(xiàn)方法,分享給大家供大家參考。相信對于大家的PHP程序設(shè)計有一定的借鑒價值。

具體代碼如下:

<?php
require 'edge.php';
$a = array(
  'a',
  'b',
  'c',
  'd',
  'e',
  'f',
  'g',
  'h',
  'i'
);
$b = array(
  'ab' => '10',
  'af' => '11',
  'gb' => '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 Edge($a, $b);
print_r($test->kruscal());
?>

edge.php文件代碼如下:

<?php
//邊集數(shù)組的邊類
class EdgeArc {
  private $begin; //起始點
  private $end; //結(jié)束點
  private $weight; //權(quán)值
  public function EdgeArc($begin, $end, $weight) {
    $this->begin = $begin;
    $this->end = $end;
    $this->weight = $weight;
  }
  public function getBegin() {
    return $this->begin;
  }
  public function getEnd() {
    return $this->end;
  }
  public function getWeight() {
    return $this->weight;
  }
}
class Edge {
  //邊集數(shù)組實現(xiàn)圖
  private $vexs; //頂點集合
  private $arc; //邊集合
  private $arcData; //要構(gòu)建圖的邊信息
  private $krus; //kruscal算法時存放森林信息
  public function Edge($vexsData, $arcData) {
    $this->vexs = $vexsData;
    $this->arcData = $arcData;
    $this->createArc();
  }
  //創(chuàng)建邊
  private function createArc() {
    foreach ($this->arcData as $key => $value) {
      $key = str_split($key);
      $this->arc[] = new EdgeArc($key[0], $key[1], $value);
    }
  }
  //對邊數(shù)組按權(quán)值排序
  public function sortArc() {
    $this->quicklySort(0, count($this->arc) - 1, $this->arc);
    return $this->arc;
  }
  //采用快排
  private function quicklySort($begin, $end, &$item) {
    if ($begin < 0($begin >= $end)) return;
    $key = $this->excuteSort($begin, $end, $item);
    $this->quicklySort(0, $key - 1, $item);
    $this->quicklySort($key + 1, $end, $item);
  }
  private function excuteSort($begin, $end, &$item) {
    $key = $item[$begin];
    $left = array();
    $right = array();
    for ($i = ($begin + 1); $i <= $end; $i++) {
      if ($item[$i]->getWeight() <= $key->getWeight()) {
        $left[] = $item[$i];
      } else {
        $right[] = $item[$i];
      }
    }
    $return = $this->unio($left, $right, $key);
    $k = 0;
    for ($i = $begin; $i <= $end; $i++) {
      $item[$i] = $return[$k];
      $k++;
    }
    return $begin + count($left);
  }
  private function unio($left, $right, $key) {
    return array_merge($left, array(
      $key
    ) , $right);
  }
  //kruscal算法
  public function kruscal() {
    $this->krus = array();
    $this->sortArc();
    foreach ($this->vexs as $value) {
      $this->krus[$value] = "0";
    }
    foreach ($this->arc as $key => $value) {
      $begin = $this->findRoot($value->getBegin());
      $end = $this->findRoot($value->getEnd());
      if ($begin != $end) {
        $this->krus[$begin] = $end;
        echo $value->getBegin() . "-" . $value->getEnd() . ":" . $value->getWeight() . "\n";
      }
    }
  }
  //查找子樹的尾結(jié)點
  private function findRoot($node) {
    while ($this->krus[$node] != "0") {
      $node = $this->krus[$node];
    }
    return $node;
  }
}
?> 

感興趣的讀者可以調(diào)試運行一下本文克魯斯卡爾算法實例,相信會有新的收獲。

相關(guān)文章

  • PHP實現(xiàn)限制IP訪問及提交次數(shù)的方法詳解

    PHP實現(xiàn)限制IP訪問及提交次數(shù)的方法詳解

    這篇文章主要介紹了PHP實現(xiàn)限制IP訪問及提交次數(shù)的方法,涉及php針對客戶端來訪IP的獲取、判斷以及結(jié)合session記錄IP訪問次數(shù)等相關(guān)操作技巧,需要的朋友可以參考下
    2017-07-07
  • php 緩存函數(shù)代碼

    php 緩存函數(shù)代碼

    簡單實用的緩存函數(shù)
    2008-08-08
  • SESSION存放在數(shù)據(jù)庫用法實例

    SESSION存放在數(shù)據(jù)庫用法實例

    這篇文章主要介紹了SESSION存放在數(shù)據(jù)庫用法,自定義了一個簡單的針對數(shù)據(jù)操作的session類并給出了使用該類存儲到數(shù)據(jù)庫的相關(guān)技巧,需要的朋友可以參考下
    2015-08-08
  • PHP實現(xiàn)的單向散列加密操作示例

    PHP實現(xiàn)的單向散列加密操作示例

    這篇文章主要介紹了PHP實現(xiàn)的單向散列加密操作,涉及PHP數(shù)據(jù)傳輸及加密解密等相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03
  • 探討GDFONTPATH能否被winxp下的php支持

    探討GDFONTPATH能否被winxp下的php支持

    本篇文章是對關(guān)于GDFONTPATH能否被winxp下的php支持進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • PHP+MySQL實現(xiàn)輸入頁碼跳轉(zhuǎn)到指定頁面功能示例

    PHP+MySQL實現(xiàn)輸入頁碼跳轉(zhuǎn)到指定頁面功能示例

    這篇文章主要介紹了PHP+MySQL實現(xiàn)輸入頁碼跳轉(zhuǎn)到指定頁面功能,結(jié)合實例形式分析了php連接mysql數(shù)據(jù)庫進行數(shù)據(jù)查詢及分頁顯示、指定頁數(shù)跳轉(zhuǎn)顯示等相關(guān)操作技巧,需要的朋友可以參考下
    2018-06-06
  • php采集中國代理服務(wù)器網(wǎng)的方法

    php采集中國代理服務(wù)器網(wǎng)的方法

    這篇文章主要介紹了php采集中國代理服務(wù)器網(wǎng)的方法,涉及php采集的相關(guān)使用技巧,需要的朋友可以參考下
    2015-06-06
  • PHP文件操作實現(xiàn)代碼分享

    PHP文件操作實現(xiàn)代碼分享

    PHP中提供了一系列的I/O函數(shù),能簡捷地實現(xiàn)我們所需要的功能,包括文件系統(tǒng)操作和目錄操作(如“復(fù)制[copy]”)。下面給大家介紹的是基本的文件讀寫操作:(1)讀文件;(2)寫文件;(3)追加到文件。
    2011-09-09
  • 淺談ThinkPHP的URL重寫

    淺談ThinkPHP的URL重寫

    關(guān)于ThinkPHP的URL重寫,其核心點基本上都是去掉URL路徑中的index.php,其余的內(nèi)容和普通的偽靜態(tài)沒有什么區(qū)別了。
    2014-11-11
  • PHP session會話操作技巧小結(jié)

    PHP session會話操作技巧小結(jié)

    這篇文章主要介紹了PHP session會話操作技巧,結(jié)合實例形式詳細總結(jié)分析了php中session會話操作的原理、配置方法、使用技巧與相關(guān)注意事項,需要的朋友可以參考下
    2016-09-09

最新評論