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解压ZIP文件到指定文件夹的方法

    PHP解压ZIP文件到指定文件夹的方法

    这篇文章主要介绍了PHP解压ZIP文件到指定文件夹的方法,结合实例形式分析了php实现的zip操作类及相应使用技巧,需要的朋友可以参考下
    2016-11-11
  • PHP调用MySQL的存储过程的实现代码

    PHP调用MySQL的存储过程的实现代码

    MySQL好像从5.0开始才引入存储过程,反正以前做应用的时候从没碰过,不过现在因为主要作内部系统
    2008-08-08
  • PHP+SQL 注入攻击的技术实现以及预防办法

    PHP+SQL 注入攻击的技术实现以及预防办法

    最近在折腾 PHP + MYSQL 的编程。了解了一些 PHP SQL 注入攻击的知识,于是写了这篇文章.
    2010-12-12
  • discuz authcode 经典php加密解密函数解析

    discuz authcode 经典php加密解密函数解析

    康盛的 authcode 函数可以说对中国的PHP界作出了重大贡献。包括康盛自己的产品,以及大部分中国使用PHP的公司都用这个函数进行加密,authcode 是使用异或运算进行加密和解密。
    2010-02-02
  • PHP实现批量重命名某个文件夹下所有文件的方法

    PHP实现批量重命名某个文件夹下所有文件的方法

    这篇文章主要介绍了PHP实现批量重命名某个文件夹下所有文件的方法,涉及php针对文件夹下文件的遍历、字符串查找、截取及rename函数重命名文件等相关操作技巧,需要的朋友可以参考下
    2017-09-09
  • PHP实现的折半查询算法示例

    PHP实现的折半查询算法示例

    这篇文章主要介绍了PHP实现的折半查询算法,结合完整实例形式分析了php使用递归与非递归实现折半查询的算法操作步骤与使用方法,需要的朋友可以参考下
    2017-10-10
  • php函数传值的引用传递注意事项分析

    php函数传值的引用传递注意事项分析

    这篇文章主要介绍了php函数传值的引用传递注意事项,涉及php配置文件的设置及数组函数的使用技巧,需要的朋友可以参考下
    2016-06-06
  • PHP二维数组去重实例分析

    PHP二维数组去重实例分析

    这篇文章主要介绍了PHP二维数组去重的方法,结合实例形式分析了php数组遍历、判断及去除重复项的相关操作技巧,需要的朋友可以参考下
    2016-11-11
  • PHP避免SQL注入的常用方法

    PHP避免SQL注入的常用方法

    在开发php网站时,经常需要和数据库交互来存储和获取数据,然而,如果不对用户输入的数据进行处理,就可能会导致SQL注入攻击,SQL注入是一种常见的安全漏洞,攻击者可以通过恶意构造的输入数据来进入到数据库中,从而获取或篡改数据的行为
    2024-04-04

最新评论