PHP常用算法和数据结构示例(必看篇)


Posted in PHP onMarch 15, 2017

实例如下:

</pre><pre name="code" class="php"><?php
/**
 * Created by PhpStorm.
 * User: qishou
 * Date: 15-8-2
 * Time: 上午9:12
 */
header("content-type:text/html;charset=utf-8");
$arr = array(3,5,8,4,9,6,1,7,2);
echo implode(" ",$arr)."<br/>";
//---------------------------------------
//       常用排序算法
//---------------------------------------
//冒泡排序
function BubbleSort($arr){
  $length = count($arr);
  if($length<=1){
    return $arr;
  }
  for($i=0;$i<$length;$i++){
    for($j=$length-1;$j>$i;$j--){
      if($arr[$j]<$arr[$j-1]){
        $tmp = $arr[$j];
        $arr[$j] = $arr[$j-1];
        $arr[$j-1] = $tmp;
      }
    }
  }
  return $arr;
}
echo '冒泡排序:';
echo implode(' ',BubbleSort($arr))."<br/>";

//快速排序
function QSort($arr){
  $length = count($arr);
  if($length <=1){
    return $arr;
  }
  $pivot = $arr[0];//枢轴
  $left_arr = array();
  $right_arr = array();
  for($i=1;$i<$length;$i++){//注意$i从1开始0是枢轴
    if($arr[$i]<=$pivot){
      $left_arr[] = $arr[$i];
    }else{
      $right_arr[] = $arr[$i];
    }
  }
  $left_arr = QSort($left_arr);//递归排序左半部分
  $right_arr = QSort($right_arr);//递归排序右半部份
  return array_merge($left_arr,array($pivot),$right_arr);//合并左半部分、枢轴、右半部分
}
echo "快速排序:";
echo implode(' ',QSort($arr))."<br/>";

//选择排序(不稳定)
function SelectSort($arr){
  $length = count($arr);
  if($length<=1){
    return $arr;
  }
  for($i=0;$i<$length;$i++){
    $min = $i;
    for($j=$i+1;$j<$length;$j++){
      if($arr[$j]<$arr[$min]){
        $min = $j;
      }
    }
    if($i != $min){
      $tmp = $arr[$i];
      $arr[$i] = $arr[$min];
      $arr[$min] = $tmp;
    }
  }
  return $arr;
}
echo "选择排序:";
echo implode(' ',SelectSort($arr))."<br/>";

//插入排序
function InsertSort($arr){
  $length = count($arr);
  if($length <=1){
    return $arr;
  }
  for($i=1;$i<$length;$i++){
    $x = $arr[$i];
    $j = $i-1;
    while($x<$arr[$j] && $j>=0){
      $arr[$j+1] = $arr[$j];
      $j--;
    }
    $arr[$j+1] = $x;
  }
  return $arr;
}
echo '插入排序:';
echo implode(' ',InsertSort($arr))."<br/>";
//---------------------------------------
//       常用查找算法
//---------------------------------------
//二分查找
function binary_search($arr,$low,$high,$key){
  while($low<=$high){
    $mid = intval(($low+$high)/2);
    if($key == $arr[$mid]){
      return $mid+1;
    }elseif($key<$arr[$mid]){
      $high = $mid-1;
    }elseif($key>$arr[$mid]){
      $low = $mid+1;
    }
  }
  return -1;
}
$key = 6;
echo "二分查找{$key}的位置:";
echo binary_search(QSort($arr),0,8,$key);

//顺序查找
function SqSearch($arr,$key){
  $length = count($arr);
  for($i=0;$i<$length;$i++){
    if($key == $arr[$i]){
      return $i+1;
    }
  }
  return -1;
}
$key = 8;
echo "<br/>顺序常规查找{$key}的位置:";
echo SqSearch($arr,$key);
//---------------------------------------
//       常用数据结构
//---------------------------------------
//线性表的删除(数组实现)
function delete_array_element($arr,$pos){
  $length = count($arr);
  if($pos<1 || $pos>$length){
    return "删除位置出错!";
  }
  for($i=$pos-1;$i<$length-1;$i++){
    $arr[$i] = $arr[$i+1];
  }
  array_pop($arr);
  return $arr;
}
$pos = 3;
echo "<br/>除第{$pos}位置上的元素后:";
echo implode(' ',delete_array_element($arr,$pos))."<br/>";

/**
 * Class Node
 * PHP模拟链表的基本操作
 */
class Node{
  public $data = '';
  public $next = null;
}
//初始化
function init($linkList){
  $linkList->data = 0; //用来记录链表长度
  $linkList->next = null;
}
//头插法创建链表
function createHead(&$linkList,$length){
  for($i=0;$i<$length;$i++){
    $newNode = new Node();
    $newNode->data = $i;
    $newNode->next = $linkList->next;//因为PHP中对象本身就是引用所以不用再可用“&”
    $linkList->next = $newNode;
    $linkList->data++;
  }
}
//尾插法创建链表
function createTail(&$linkList,$length){
  $r = $linkList;
  for($i=0;$i<$length;$i++){
    $newNode = new Node();
    $newNode->data = $i;
    $newNode->next = $r->next;
    $r->next = $newNode;
    $r = $newNode;
    $linkList->data++;
  }
}
//在指定位置插入指定元素
function insert($linkList,$pos,$elem){
  if($pos<1 && $pos>$linkList->data+1){
    echo "插入位置错误!";
  }
  $p = $linkList;
  for($i=1;$i<$pos;$i++){
    $p = $p->next;
  }
  $newNode = new Node();
  $newNode->data = $elem;
  $newNode->next = $p->next;
  $p->next = $newNode;
}
//删除指定位置的元素
function delete($linkList,$pos){
  if($pos<1 && $pos>$linkList->data+1){
    echo "位置不存在!";
  }
  $p = $linkList;
  for($i=1;$i<$pos;$i++){
    $p = $p->next;
  }
  $q = $p->next;
  $p->next = $q->next;
  unset($q);
  $linkList->data--;
}
//输出链表数据
function show($linkList){
  $p = $linkList->next;
  while($p!=null){
    echo $p->data." ";
    $p = $p->next;
  }
  echo '<br/>';
}

$linkList = new Node();
init($linkList);//初始化
createTail($linkList,10);//尾插法创建链表
show($linkList);//打印出链表
insert($linkList,3,'a');//插入
show($linkList);
delete($linkList,3);//删除
show($linkList);

/**
 * Class Stack
 * 用PHP模拟顺序栈的基本操作
 */
class Stack{
  //用默认值直接初始化栈了,也可用构造方法初始化栈
  private $top = -1;
  private $maxSize = 5;
  private $stack = array();

  //入栈
  public function push($elem){
    if($this->top >= $this->maxSize-1){
      echo "栈已满!<br/>";
      return;
    }
    $this->top++;
    $this->stack[$this->top] = $elem;
  }
  //出栈
  public function pop(){
    if($this->top == -1){
      echo "栈是空的!";
      return ;
    }
    $elem = $this->stack[$this->top];
    unset($this->stack[$this->top]);
    $this->top--;
    return $elem;
  }
  //打印栈
  public function show(){
    for($i=$this->top;$i>=0;$i--){
      echo $this->stack[$i]." ";
    }
    echo "<br/>";
  }
}

$stack = new Stack();
$stack->push(3);
$stack->push(5);
$stack->push(8);
$stack->push(7);
$stack->push(9);
$stack->push(2);
$stack->show();
$stack->pop();
$stack->pop();
$stack->pop();
$stack->show();

/**
 * Class Deque
 * 使用PHP实现双向队列
 */
class Deque{
  private $queue = array();
  public function addFirst($item){//头入队
    array_unshift($this->queue,$item);
  }
  public function addLast($item){//尾入队
    array_push($this->queue,$item);
  }
  public function removeFirst(){//头出队
    array_shift($this->queue);
  }
  public function removeLast(){//尾出队
    array_pop($this->queue);
  }
  public function show(){//打印
    foreach($this->queue as $item){
      echo $item." ";
    }
    echo "<br/>";
  }
}
$deque = new Deque();
$deque->addFirst(2);
$deque->addLast(3);
$deque->addLast(4);
$deque->addFirst(5);
$deque->show();

//PHP解决约瑟夫环问题
//方法一
function joseph_ring($n,$m){
  $arr = range(1,$n);
  $i = 0;
  while(count($arr)>1){
    $i=$i+1;
    $head = array_shift($arr);
    if($i%$m != 0){ //如果不是则重新压入数组
      array_push($arr,$head);
    }
  }
  return $arr[0];
}
//方法二
function joseph_ring2($n,$m){
  $r = 0;
  for($i=2;$i<=$n;$i++){
    $r = ($r+$m)%$i;
  }
  return $r + 1;
}
echo "<br/>".joseph_ring(60,5)."<br/>";
echo "<br/>".joseph_ring2(60,5)."<br/>";

以上这篇PHP常用算法和数据结构示例(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
mysql_num_rows VS COUNT 效率问题分析
Apr 23 PHP
解析PHP中常见的mongodb查询操作
Jun 20 PHP
PHP fastcgi模式上传大文件(大约有300多K)报错
Sep 28 PHP
php中getservbyport与getservbyname函数用法实例
Nov 18 PHP
简单谈谈php中的unicode和utf8编码
Jun 10 PHP
php生成图片验证码的实例讲解
Aug 03 PHP
Thinkphp框架 表单自动验证登录注册 ajax自动验证登录注册
Dec 27 PHP
php判断str字符串是否是xml格式数据的方法示例
Jul 26 PHP
php mysql数据库操作类(实例讲解)
Aug 06 PHP
PHP编程实现计算抽奖概率算法完整实例
Aug 09 PHP
PHP多进程编程之僵尸进程问题的理解
Oct 15 PHP
php单元测试phpunit入门实例教程
Nov 17 PHP
thinkPHP数据查询常用方法总结【select,find,getField,query】
Mar 15 #PHP
wordpress网站转移到本地运行测试的方法
Mar 15 #PHP
thinkPHP+ajax实现统计页面pv浏览量的方法
Mar 15 #PHP
PHP判断是手机端还是PC端 PHP判断是否是微信浏览器
Mar 15 #PHP
thinkPHP简单导入和使用阿里云OSSsdk的方法
Mar 15 #PHP
YII中Ueditor富文本编辑器文件和图片上传的配置图文教程
Mar 15 #PHP
thinkPHP简单调用函数与类库的方法
Mar 15 #PHP
You might like
用PHP和ACCESS写聊天室(三)
2006/10/09 PHP
解析php中获取系统信息的方法
2013/06/25 PHP
PHP curl CURLOPT_RETURNTRANSFER参数的作用使用实例
2015/02/07 PHP
Zend Framework实现具有基本功能的留言本(附demo源码下载)
2016/03/22 PHP
Js setInterval与setTimeout(定时执行与循环执行)的代码(可以传入参数)
2010/06/11 Javascript
页面定时刷新(1秒刷新一次)
2013/11/22 Javascript
jQuery中is()方法用法实例
2015/01/06 Javascript
jQuery选择器源码解读(四):tokenize方法的Expr.preFilter
2015/03/31 Javascript
基于zepto.js简单实现上传图片
2016/06/21 Javascript
Angular+Node生成随机数的方法
2017/06/16 Javascript
使用JavaScript实现一个小程序之99乘法表
2017/09/21 Javascript
EL表达式截取字符串的函数说明
2017/09/22 Javascript
JS实现的透明度渐变动画效果示例
2018/04/28 Javascript
微信小程序通过js实现瀑布流布局详解
2019/08/28 Javascript
微信小程序 多行文本显示...+显示更多按钮和收起更多按钮功能
2019/09/26 Javascript
React冒泡和阻止冒泡的应用详解
2020/08/18 Javascript
VUE中鼠标滚轮使div左右滚动的方法详解
2020/12/14 Vue.js
[01:29:46]DOTA2上海特级锦标赛C组资格赛#1 OG VS LGD第二局
2016/02/27 DOTA
使用python绘制常用的图表
2016/08/27 Python
深入理解 Python 中的多线程 新手必看
2016/11/20 Python
python批量读取文件名并写入txt文件中
2020/09/05 Python
pytorch打印网络结构的实例
2019/08/19 Python
Centos7下源码安装Python3 及shell 脚本自动安装Python3的教程
2020/03/07 Python
Python字符串三种格式化输出
2020/09/17 Python
Python实现疫情地图可视化
2021/02/05 Python
Goodee官方商店:迷你投影仪
2021/03/15 全球购物
求高于平均分的学生学号及成绩
2016/09/01 面试题
党员领导干部民主生活会批评与自我批评发言
2014/09/28 职场文书
教师三严三实学习心得体会
2014/10/11 职场文书
社区党务工作总结2015
2015/05/19 职场文书
雷锋的观后感
2015/06/10 职场文书
学校学期工作总结
2015/08/13 职场文书
学生病假条怎么写
2015/08/17 职场文书
创业计划书之儿童理发店
2019/09/27 职场文书
Android studio 简单计算器的编写
2022/05/20 Java/Android
windows server2016安装oracle 11g的图文教程
2022/07/15 Servers