PHP实现克鲁斯卡尔算法实例解析

2015-01-24信息快讯网

这篇文章主要介绍了PHP实现克鲁斯卡尔算法实例解析,是PHP程序设计中一个比较经典的应用,需要的朋友可以参考下

本文实例展示了PHP实现的格鲁斯卡尔算法(kruscal)的实现方法,分享给大家供大家参考。相信对于大家的PHP程序设计有一定的借鉴价值。

具体代码如下:

<?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
//边集数组的边类
class EdgeArc {
  private $begin; //起始点
  private $end; //结束点
  private $weight; //权值
  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 {
  //边集数组实现图
  private $vexs; //顶点集合
  private $arc; //边集合
  private $arcData; //要构建图的边信息
  private $krus; //kruscal算法时存放森林信息
  public function Edge($vexsData, $arcData) {
    $this->vexs = $vexsData;
    $this->arcData = $arcData;
    $this->createArc();
  }
  //创建边
  private function createArc() {
    foreach ($this->arcData as $key => $value) {
      $key = str_split($key);
      $this->arc[] = new EdgeArc($key[0], $key[1], $value);
    }
  }
  //对边数组按权值排序
  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";
      }
    }
  }
  //查找子树的尾结点
  private function findRoot($node) {
    while ($this->krus[$node] != "0") {
      $node = $this->krus[$node];
    }
    return $node;
  }
}
?> 

感兴趣的读者可以调试运行一下本文克鲁斯卡尔算法实例,相信会有新的收获。

PHP和Shell实现检查SAMBA与NFS Server是否存在
PHP实现的简易版图片相似度比较
PHP中使用SimpleXML检查XML文件结构实例
php中$_POST与php://input的区别实例分析
php静态文件返回304技巧分享
php实现utf-8转unicode函数分享
php基于表单密码验证与HTTP验证用法实例
PHP中$this和$that指针使用实例
php缓冲输出实例分析
php中Socket创建与监听实现方法
php实现计数器方法小结
php中最简单的字符串匹配算法
PHP冒泡算法详解(递归实现)
PHP 快速排序算法详解
PHP大转盘中奖概率算法实例
PHP实现AES256加密算法实例
ThinkPHP中的三大自动简介
php中限制ip段访问、禁止ip提交表单的代码分享
PHP中new static()与new self()的区别异同分析
PHP中的替代语法简介
destoon实现不同会员组公司名称显示不同的颜色的方法
destoon实现会员商铺中指定会员或会员组投放广告的方法
destoon实现调用图文新闻的方法
destoon切换城市后实现logo旁边显示地区名称的方法
destoon调用discuz论坛中带图片帖子的实现方法
PHP实现ftp上传文件示例
PHP高手需要要掌握的知识点
PHP中比较时间大小实例
PHP中使用sleep函数实现定时任务实例分享
又一个PHP实现的冒泡排序算法分享
PHP面向对象程序设计之类常量用法实例
PHP文件缓存内容保存格式实例分析
实例讲解PHP面向对象之多态
PHP中对各种加密算法、Hash算法的速度测试对比代码
php实现的短网址算法分享
php实现信用卡校验位算法THE LUHN MOD-10示例
php对称加密算法示例
©2014-2024 dbsqp.com