?php
/**
* Created by PhpStorm.
* User: jinlei
* Date: 17/11-1
* 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).”
“;
//—————————————
// 常用排序算法
//—————————————
//冒泡排序
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))."
“;

//快速排序
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))."
“;

//选择排序(不稳定)
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))."
“;

//插入排序
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)).”
“;
//—————————————
// 常用查找算法
//—————————————
//二分查找
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 "
顺序常规查找{$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 "
除第{$pos}位置上的元素后:”;
echo implode(‘ ‘,delete_array_element($arr,$pos)).”
“;

/**
* 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 ‘
‘;
}

$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 “栈已满!
“;
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 “
“;
}
}

$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 “
“;
}
}
$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; }

转载于:https://www.cnblogs.com/cjymuyang/p/9448513.html

php算法和数据结构相关推荐

  1. GitHub上分享的常用算法和数据结构实现原理可视化系统

    一门编程语言入门之后,要想进阶,必须学习算法和数据结构,但是对于初学者来讲算法和数据结构和数据结构的实现原理和机制过于枯涩.抽象难懂. 这里为小伙伴们分享一个名为Algorithm Visualize ...

  2. 维基百科上的算法和数据结构链接很强大

    突然发现维基百科上的算法和数据结构比百度百科强多啦,图文并茂. 其实这个网站不错:http://www.sorting-algorithms.com 冒泡排序: bubble冒泡的意思 http:// ...

  3. GitHub标星3w+的项目,全面了解算法和数据结构知识

    作者 | 程序员小吴 来源 | 五分钟学算法(ID: CXYxiaowu) 导语:今天分享一个开源项目,里面汇总了程序员技术面试时需要了解的算法和数据结构知识,并且还提供了相应的代码,目前 GitHu ...

  4. noj数据结构稀疏矩阵的加法十字链表_一个算法毁了一款好游戏?算法和数据结构到底有多重要?...

    来源 | 异步 | 文末赠书 前段时间大火的国产游戏--<太吾绘卷>,由于创新的玩法和精良的制作一度广受好评,然而随着玩家游戏的深入和时长的积累,发现该游戏在玩的过程中游戏外的问题很多很多 ...

  5. 浅谈算法和数据结构: 五 优先级队列与堆排序

    原文:浅谈算法和数据结构: 五 优先级队列与堆排序 在很多应用中,我们通常需要按照优先级情况对待处理对象进行处理,比如首先处理优先级最高的对象,然后处理次高的对象.最简单的一个例子就是,在手机上玩游戏 ...

  6. java优先队列的入队函数,算法与数据结构番外(1):优先队列

    这是算法与数据结构番外系列的第一篇,这个系列未来的主要内容是补充一些与算法与数据结构相关的知识,这些知识比较零碎,同时也与正传关系密切,往往需要阅读了正传的相关内容以后,才能较好的理解这部分内容.如果 ...

  7. 算法与数据结构(2)

    算法与数据结构(2) 三年前发布过一篇算法与数据结构 https://blog.csdn.net/weixin_42209307/article/details/81122419?spm=1001.2 ...

  8. 算法与数据结构(面向对象思想)

    算法与数据结构和编程之间关系 计算机就是算法与数据结构, 当你选择搜索这类的文章的时候,你已经在翻大山了 编程就是当你翻过一座山的时候,你发现前面还有一座更高的山. LZ从事java工作一年了,最近听 ...

  9. python数据结构推荐书-「算法与数据结构」从入门到进阶吐血整理推荐书单

    推荐一下「算法与数据结构」从入门到进阶的书单. 一.入门系列 这些书籍通过图片.打比方等通俗易懂的方法来讲述,让你能达到懂一些基础算法,线性表,堆栈,队列,树,图,DP算法,背包问题等,不要求会实现, ...

  10. python教材免费版-北大内部教材python版算法与数据结构PDF电子书免费下载

    自从第一台需要人们用线缆和交换机向其传达指令的电子计算机问世以来,编程已发生了巨大改变.计算机科技的革新给计算机科学家提供了越来越多的工具和平台,方便他们在社会的各个领域一显身手.高速处理器.高速网络 ...

最新文章

  1. 消息队列处理微信支付超时订单
  2. wavelet tutorial
  3. express组合gulp自动更新代码重启浏览器
  4. Gulp:自动化构建工具
  5. EF架构~为IEnumerable接口添加增删查等操作,原因是IEnumerable导航属性更放心
  6. 利用sqoop将hive数据导入导出数据到mysql
  7. 基于MySQL的高可用可扩展架构探讨
  8. 转载构造函数与拷贝构造函数
  9. can‘t decrement vector iterator before begin
  10. 计算机更新配置卡住了,win10更新设置卡死怎么办|win10更新设置卡死的完美解决方法...
  11. VMwareWorkstation16环境下安装kali-linux-2021.2版本虚拟机(最新版本)
  12. Oracle练习题(三)
  13. QString常用方法介绍
  14. 数字图像处理_Matlab——车牌识别分析
  15. 司法背记一表通(吐血整理!!)
  16. C语言标识符有哪三类
  17. python数据类型有序无序,python数据类型有序无序_python中的有序和无序类别变量...
  18. 光线传媒副总裁刘同:我们为什么要读大学?
  19. 【虚拟仿真】Unity3D中拆分模型教程(多种类型模型拆分)
  20. 使用scrapy爬取qq音乐

热门文章

  1. 服务器一般在什么位置,云服务器比较普通服务器差异在哪里
  2. 快过年了,用JS让你的网页放烟花吧
  3. HTTP请求Content-Type你知道是做什么的吗?
  4. 8个提高工作效率的Web前端开发框架总结
  5. python工作区是什么_在IPython中保存工作区
  6. keil流水灯c语言程序两个一起亮,Keil单片机点亮一个灯及循环流水灯三种实现方法详解...
  7. php中global什么意思,php中global和$GLOBALS[]的用法、解释、区别
  8. eclipse使用python_【转】使用Python的IDE:Eclipse+PyDev
  9. 升级华为鸿蒙os2.0名单,鸿蒙OS 2.0正式版升级名单确认!这10款机型用户先恭喜了...
  10. Linux 防火墙安装包下载,IPFire 2.23 Core Update 138 发布下载,Linux开源防火墙发行版...