PHP实现的栈数据结构示例【入栈、出栈、遍历栈】

 更新时间:2017年12月11日 11:08:21   作者:根号五  
这篇文章主要介绍了PHP实现的栈数据结构,结合实例形式分析了php定义栈及入栈、出栈、遍历栈等相关操作技巧,需要的朋友可以参考下

本文实例讲述了PHP实现的栈数据结构。分享给大家供大家参考,具体如下:

利用php面向对象思想,栈的属性有top、最大存储数、和存储容器(这里利用了php数组)。

代码如下:实现了入栈、出栈、遍历栈的几个方法:

<?php
class Stack{
  const MAXSIZE = 4;// 栈最大容量
  private $top = -1;
  private $stack = array();// 利用数组存储数据
  public function __construct(){
    $this->stack = array();
  }
  // 入栈
  public function push($ele){
    if ($this->top >= self::MAXSIZE-1){
      echo 'stack is full...';
      return false;
    }
    $this->stack[++$this->top] = $ele;// 此处必须是++i,先计算再使用
  }
  // 出栈,返回出栈元素
  public function pop(){
    if ($this->top == -1){
      echo 'stack is empty...';
      return false;
    }
    $ele = $this->stack[$this->top];
    unset($this->stack[$this->top--]);// 此处必须是i--,先使用再计算(注意出栈和入栈的区别)
    return $ele;
  }
  // 遍历栈
  public function show(){
    if ($this->top == -1){
      echo 'stack is empty...';
      return false;
    }
    for($i=$this->top; $i>-1; $i--){
      echo $this->stack[$i].'<br/>';
    }
  }
}
$stack = new Stack;
$stack->push(1);
$stack->push(2);
$stack->push(3);
$stack->push(4);
//print_r($stack);
$stack->show();
$a = $stack->pop();
$a = $stack->pop();
$a = $stack->pop();
$stack->show();

运行结果:

4
3
2
1
1

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数据结构与算法教程》、《php程序设计算法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP常用遍历算法与技巧总结》及《PHP数学运算技巧总结

希望本文所述对大家PHP程序设计有所帮助。

相关文章

  • PHP连接数据库实现注册页面的增删改查操作

    PHP连接数据库实现注册页面的增删改查操作

    这篇文章主要介绍了PHP连接数据库实现注册页面的增删改查操作,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • php计算整个目录大小的方法

    php计算整个目录大小的方法

    这篇文章主要介绍了php计算整个目录大小的方法,涉及php针对目录操作的相关技巧,需要的朋友可以参考下
    2015-06-06
  • PHP实现的62进制转10进制,10进制转62进制函数示例

    PHP实现的62进制转10进制,10进制转62进制函数示例

    这篇文章主要介绍了PHP实现的62进制转10进制,10进制转62进制函数,结合具体实例形式分析了php针对62进制与10进制相互转换的操作技巧,需要的朋友可以参考下
    2019-06-06
  • php判断目录存在的简单方法

    php判断目录存在的简单方法

    在本篇文章里小编给大家分享了关于php判断目录是否存在的相关知识点,有需要的朋友们参考学习下。
    2019-09-09
  • 使用PHP8提升开发效率的技巧分享

    使用PHP8提升开发效率的技巧分享

    PHP 8 是 PHP 语言的一个重要版本,引入了许多新特性和改进,旨在提高开发效率,本文将探讨一下PHP 8如何通过各种功能和语言改进来促进开发效率的提升,感兴趣的小伙伴可以了解下
    2023-11-11
  • PHP浮点比较大小的方法

    PHP浮点比较大小的方法

    这篇文章主要介绍了PHP浮点比较大小的方法,涉及PHP数字及字符串的转换与比较相关技巧,需要的朋友可以参考下
    2016-02-02
  • PHP函数常用用法小结

    PHP函数常用用法小结

    由于PHP是一种解释型语言,所以函数编写和调用很是方便。总结一下魔术函数、嵌套函数、匿名函数、函数调用方式和函数参数使用等。
    2010-02-02
  • 浅谈PHP中常用的3种设计模式

    浅谈PHP中常用的3种设计模式

    设计模式是针对软件开发中出现的常见问题的可重用解决方案,在本文中,我们将探讨在PHP开发中广泛使用的三种流行设计模式:单例模式、工厂模式和观察者模式,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • PHP魔术引号所带来的安全问题分析

    PHP魔术引号所带来的安全问题分析

    这篇文章主要介绍了PHP魔术引号所带来的安全问题分析,对于安全编码来说非常重要!需要的朋友可以参考下
    2014-07-07
  • 原生php实现excel文件读写的方法分析

    原生php实现excel文件读写的方法分析

    这篇文章主要介绍了原生php实现excel文件读写的方法,结合实例形式分析了采用原生php针对Excel进行读写操作的相关实现方法与操作注意事项,需要的朋友可以参考下
    2018-04-04

最新评论