数据结构随笔-php实现栈
栈(Stack)满足后进先出(LIFO)的原则;
下面利用php实现栈的相关操作;
本实例栈的基本操作:
入栈(push):向栈内压入一个元素,栈顶指针指向栈顶元素
出栈(pop): 从栈顶去除元素,栈顶指针向栈底移动;
判空(isEmpty):当栈顶指针恢复为初始指针状态即为空栈;
判满(isFull): 当栈顶等于容量减一则栈满;
使用php数组实现一个简单操作的栈;
<?php /**
* Created by PhpStorm.
* User: gordon
* Date: 2017/8/6
* Time: 12:58
*/ /**
* Class Stack 简单栈
*/
class Stack
{
/**
* 栈初始指针
*/
const TOP_INIT = -1; /**
* 栈底指针
*/
const BOTTOM = 0;
/**
* @var array 栈数组
*/
private $_stack; /**
* @var int 栈顶指针
*/
private $_stackTop; /**
* @var int 栈的容量
*/
private $_stackSize; /**
* Stack constructor. 初始化栈
* @param int $size 栈的容量大小;
*/
public function __construct($size)
{
$this->_stack = [];
$this->_stackSize = $size; /**
* 栈顶初始状态位于栈底
*/
$this->_stackTop = self::TOP_INIT;
} /**
* @method 销毁栈(非必需)
*/
public function __destruct()
{
unset($this->_stack);
} /**
* @method 入栈
* @param mixed $elem 入栈元素
* @return bool
*/
public function push($elem)
{
if ($this->isFull()) {
return false;
}
$this->_stack[++$this->_stackTop] = $elem;
return true;
} /**
* @method 出栈
* @return mixed|null 返回栈顶的元素或者当栈为空时返回null
*/
public function pop()
{
if ($this->isEmpty()) {
return null;
}
$result = $this->_stack[$this->_stackTop];
unset($this->_stack[$this->_stackTop]);
$this->_stackTop--;
return $result;
} /**
* @method 判断栈是否为空;
* @return bool
*/
public function isEmpty()
{
return $this->_stackTop === self::TOP_INIT;
} /**
* @method 判断栈是否达到最大;
* @return bool
*/
public function isFull()
{
return $this->_stackSize - 1 === $this->_stackTop;
} /**
* @method 清空栈
*/
public function clearStack()
{
$this->_stack = [];
$this->_stackTop = self::TOP_INIT;
} /**
* @method 遍历栈(测试用);
*/
public function outputStack()
{
echo 'take traversal stack from bottom to top'.PHP_EOL;
for ($i = self::BOTTOM; $i < $this->_stackTop + 1; $i++) {
echo $this->_stack[$i].PHP_EOL;
}
echo PHP_EOL;
echo PHP_EOL;
echo 'take traversal stack from top to bottom'.PHP_EOL;
for ($i = $this->_stackTop; $i >= self::BOTTOM; $i--) {
echo $this->_stack[$i].PHP_EOL;
}
}
}
测试一下栈操作类
$s = new Stack(4); $s->push(1);
$s->push(2);
$s->push(3);
$s->push(4);
$s->push(5);
$s->outputStack(); //stack from top to bottom: 4 3 2 1
$s->pop(); //output:4 stack: 3 2 1
$s->pop(); //output:3 stack: 2 1
$s->outputStack(); //stack: 2 1
$s->push(5);
$s->outputStack(); //stack: 5 2 1
$s->clearStack();
var_dump($s->pop()); //null;
经过测试代码很讲道理;
如有不对,敬请指教
数据结构随笔-php实现栈的更多相关文章
- php数据结构课程---4、栈(是什么)
php数据结构课程---4.栈(是什么) 一.总结 一句话总结: 栈(stack),它是一种运算受限的线性表.其限制是仅允许在表的一端进行插入和删除运算. 1.栈的链表实现? 定义node,设置属性d ...
- java实现 数据结构:链表、 栈、 队列、优先级队列、哈希表
java实现 数据结构:链表. 栈. 队列.优先级队列.哈希表 数据结构javavector工作importlist 最近在准备找工作的事情,就复习了一下java.翻了一下书和网上的教材,发现虽然 ...
- 我理解的数据结构(二)—— 栈(Stack)
我理解的数据结构(二)-- 栈(Stack) 一.栈基础 栈是一种线性结构 相比较数组,栈对应的操作是数组的子集 只能从一端添加元素,也只能从同一端取出元素,这一端称为栈顶 栈是一种后进先出的数据结构 ...
- JS数据结构第四篇 --- 栈
一.什么是数据结构栈 在数据结构中有一个栈结构,在内存空间中也有一个栈空间,这两个”栈“是两个不同的概念.这篇我们说的是数据结构中的栈.栈是一种特殊的线性表,特殊性在哪?就是只能在栈顶进行操作,往栈顶 ...
- 数据结构之队列and栈总结分析
一.前言: 数据结构中队列和栈也是常见的两个数据结构,队列和栈在实际使用场景上也是相辅相成的,下面简单总结一下,如有不对之处,多多指点交流,谢谢. 二.队列简介 队列顾名思义就是排队的意思,根据我们的 ...
- 数据结构:C_顺序栈的实现
数据结构顺序栈的实现(C语言版) 1.写在前面 栈是一种遵循元素先进(Push)后出(Pop)规则的线性表,它的实现可以用数组或者链表. ..... 2.代码分解 2.1对栈的结构定义: typede ...
- 用JS描述的数据结构及算法表示——栈和队列(基础版)
前言:找了上课时数据结构的教程来看,但是用的语言是c++,所以具体实现在网上搜大神的博客来看,我看到的大神们的博客都写得特别好,不止讲了最基本的思想和算法实现,更多的是侧重于实例运用,一边看一边在心里 ...
- C++数据结构之Stack(栈)
stack,栈,是好比堆积木似的数据结构,从上之下堆积,取出时按"LIFO"-last int first out后进先出的规则.栈一般为线程所独有,也就是每个线程有其自有的栈,与 ...
- 【Java数据结构学习笔记之二】Java数据结构与算法之栈(Stack)实现
本篇是java数据结构与算法的第2篇,从本篇开始我们将来了解栈的设计与实现,以下是本篇的相关知识点: 栈的抽象数据类型 顺序栈的设计与实现 链式栈的设计与实现 栈的应用 栈的抽象数据类型 栈是 ...
随机推荐
- 今天学习js做了些总结,分享给大家
一.1.javascript的作用 是基于对象和事件驱动的语言,应用于客户端 基于对象:提供好了很多对象,可以直接拿过来使用,不需要创建 事件驱动: html做网站静态效果,javascr ...
- 网络组Network Teaming
网络组team:是将多个网卡聚合在一起,从而实现容错和提高吞吐量 1 创建网络组接口 nmcli connection add type team con-name TEAMname ifname I ...
- golang中defer的使用规则
转自个人博客chinazt.cc 在golang当中,defer代码块会在函数调用链表中增加一个函数调用.这个函数调用不是普通的函数调用,而是会在函数正常返回,也就是return之后添加一个函数调用. ...
- Ext template 的使用
Ext template 的使用 Ext.define('app.view.MyDataView', { extend: 'Ext.panel.Panel', xtype: 'myDataView', ...
- MySQL(三)--函数与谓词
前文已有涉及,这里作为总结重新整理一下. 一.函数 1.算术函数 NUMERIC 是大多数 DBMS 都支持的一种数据类型,通过 NUMBERIC ( 全体位数, 小数位数 ) 的形式来指定数值的大小 ...
- FAT文件系统学习和思考
FAT(File Allocation Table)文件系统 前两天面试,导师说我基础差,要赶紧补起来了.今天晚上看了FAT32文件系统,基本的信息都是百度百科中"FAT文件系统" ...
- (转载)Oracle10g 数据泵导出命令 expdp 使用总结(二)
原文链接:http://hi.baidu.com/edeed/item/2c454cff5c559f773d198b94 Oracle10g 数据泵导出命令 expdp 使用总结(一) 1.1.2 e ...
- 数据结构3——浅谈zkw线段树
线段树是所有数据结构中,最常用的之一.线段树的功能多样,既可以代替树状数组完成"区间和"查询,也可以完成一些所谓"动态RMQ"(可修改的区间最值问题)的操作.其 ...
- Randoop测试类和方法(用例自动生成)
详细使用方法见randoop官网: https://randoop.github.io/randoop/manual/index.html 测试程序之前,先检测下你的Randoop是否配置好: 打开c ...
- wifi扩展设置
一.主路由器设置 网络参数 LAN口设置查到 MAC地址,用于设置扩展路由器 Bridge功能设置时 AP1的地址 2.无线基本设置,桥的 SSID BSSID 为扩展 3.无线安全设置 二.扩展路由 ...