PHP实现简单顺序栈

栈与数组:php数组也有压入压出的方法array_push 和array_shift。是不是数组就是栈数据结构?或者明明数组就可完成,为何还要栈

解答:去全国各地都可以用双腿走到,为何选择火车飞机?数组就是腿,栈就是火车飞机。首先不相等,其次栈可以让我们集中精力去解决更加核心的业务需求。

简单顺序栈实现

class Data{
   private $data; 
   public function __construct($data){
        $this->data=$data;         
   } 

   public function getData(){
        return $this->data;
   }
} 

class Stack{
    private $size;
    private $top;//栈顶的标识
    private $stack=array();

    public function __construct($size){
        return $this->Init_Stack($size);
    }
    public function Init_Stack($size){
        $this->size=$size;
        $this->top=-1;//这里栈顶的位置元素
    }

    public function Empty_Stack(){
        if($this->top==-1) return 1;
        else
            return 0;
    }

    public function Full_Stack(){
        if($this->top<($this->size-1)) return 0;
        else
            return 1;
    }
//入栈
//本来打算直接算入Data对象,后来试验了下好像有个小问题,就是单例的问题吧,看来还是需要每次都新建一个
/**
*@param $data class Data 的成员
*
**/
    public function Push_Stack($data){
        if($this->Full_Stack()) echo "栈满了";
        else
            $this->stack[++$this->top] = new Data($data);
    }

    //出栈
    public function Pop_Stack(){
        if($this->Empty_Stack()) echo "栈空无数据!";
        else
            unset($this->stack[$this->top--]);
    }
    //读取栈顶元素
    public function Top_Stack(){
        return $this->Empty_Stack()?"栈空无数据":$this->stack[$this->top]->getData();
        /*return $this->Empty_Stack()?"栈空无数据!":$this->stack[$this->top]->getData(); */
    }
}

//测试
//$data1 =new Data(‘hello‘);
$data1=‘mini‘;
$stock =new Stack(5); 
$stock->Push_Stack(‘jack‘);
$stock->Push_Stack($data1);
$stock->Push_Stack($data1);
$stock->Push_Stack($data1);
$stock->Empty_Stack();
$stock->Pop_Stack();
$stock->Pop_Stack();
$stock->Pop_Stack();
//$stock->Pop_Stack();
////$stock->Push_Stack(‘‘);
//$stock->
echo $stock->Top_Stack();
?>

关于循环链表和双向链表,没有再写。顺序存储还是比较好理解。

补充关于栈的软件应用:Word,PS,浏览器常用的撤销或者后退

补充栈拥有线性表的所有特性:上面是可以补充进来几个函数:DestroyStack(销毁)ClearStack(清空)StackLength(长度)。所有函数只是一次演练,熟悉下思路,下次写任何业务逻辑,符合需要的话可以直接使用该思想

时间: 2024-10-25 11:05:08

PHP实现简单顺序栈的相关文章

顺序栈的简单操作

今天简单的实现了一下顺序栈,栈的核心函数是push(),top(),pop().首先是我自己编写的栈,后面是STL标准库调用栈函数. sqstack.h //栈的简单实现lifo #ifndef SQSTACK_H_ #define SQSTACK_H_ const int DEFAULT_SIZE=10; #include <iostream> using std::cout; using std::endl; template <typename T> class Sqstac

hdu-1237简单计算器(栈的运用)

http://acm.hdu.edu.cn/showproblem.php?pid=1237 简单的栈的运用. 首先将数字和运算符分离,分别保存在两个数组中,然后按原来的式子的顺序,首先将第一个数和第一个运算符分别压 如个自的栈,然后判取出两个栈头部的元素,判断符号,如果是乘除就用当前数值乘取出的数字(优先),然后将乘后的数压入栈, 如果是加则将数和取出的数按原序入栈,如果减,就把新的数变负,将数和取出的数按原序入栈. 最后栈中所有元素的和就是结果. 1 #include<stdio.h> 2

小猪的数据结构辅助教程——3.1 栈与队列中的顺序栈

小猪的数据结构辅助教程--3.1 栈与队列中的顺序栈 标签(空格分隔): 数据结构 本节学习路线图与学习要点 学习要点 1.栈与队列的介绍,栈顶,栈底,入栈,出栈的概念 2.熟悉顺序栈的特点以及存储结构 3.掌握顺序栈的基本操作的实现逻辑 4.掌握顺序栈的经典例子:进制变换的实现逻辑 1.栈与队列的概念: 嗯,本节要进行讲解的就是栈 + 顺序结构 = 顺序栈! 可能大家对栈的概念还是很模糊,我们找个常见的东西来拟物化~ 不知道大家喜欢吃零食不--"桶装薯片"就可以用来演示栈! 生产的时

顺序栈操作--数据结构(C++)版

最近学习数据结构,一开始接触感觉好难,颓废了一段时间,后来又重新翻开学习,突然感觉到很大的兴趣.对这些代码的运用都有了 一些新的认识.下面简单的讲述下最新学到的顺序栈,不知道大家学习的时候会不会有感觉,书上写的那么简单,但是我写的都是不对,不是这里有错就是那里有错,最后还是攻克了,心理慢慢地成就感. 题目大概:输入一串整数,如果 该数不等于-1,就进栈,若是等于-1,则输出栈顶整数并出栈.同时算法给出应对异常的情况. 代码实现 #include <stdio.h>#include <st

【数据结构之旅】顺序栈入门操作

说明: 书中已有关于顺序栈的类型定义.栈初始化.入栈操作,显然这些都是比较理论的算法,书中并没有给出一个完整可以执行的例子,这对初学者学习在理解上会有一定的难度,因此,需要编写一个简单的例子来理解栈的最基本操作. 1.程序功能 通过使用栈来编写一个程序,实现两个数的交换. 2.程序代码及注释 代码及注释如下: #include<stdio.h> #include<stdlib.h>    //导入stdlib.h模块是为了使用sizeof函数 typedef struct{    

数据结构第七篇——顺序栈

?注:未经博主同意,不得转载. 栈(stack)是常用的重要数据结构,其应用十分广泛.栈是一个操作受限的线性表,其插入和删除操作都在表的同一端进行. 其中允许操作的一端称为栈顶(top),另一端称为栈底(bottom),不含元素的栈称为空栈. 栈的修改是按后进先出的原则进行的,因此,栈称为后进先出表(Last In First Out,LIFO).称插入元素的操作为入栈(push),删除元素的操作为出栈(pop). 栈由元素列表.指向栈顶的下标或指针以及栈的操作集组成.栈的具体实现有两种方式:顺

数据结构:C_顺序栈的实现

数据结构顺序栈的实现(C语言版) 1.写在前面 栈是一种遵循元素先进(Push)后出(Pop)规则的线性表,它的实现可以用数组或者链表. ..... 2.代码分解 2.1对栈的结构定义: typedef struct { int *base; int *top; int stacksize; }SqStack; |说明: 1.base表示栈底指针,在判断出栈.初始化和重新分配空间的时候需要用到. 2.top表示栈顶指针,是栈最关键和核心的组成,入栈时top向上移动,出栈时top向下移动. 3.此

数据结构与算法——顺序栈

今天总结栈的顺序存储结构 什么是栈? 栈是一种线性表,其特点是限定尽在表尾进行插入和删除操作,表尾栈一段也叫栈顶,另一端就是栈底了.既然栈是线性表,那么栈也就有两种存储数据的方式,顺序存储和链式存储.今天实现的是顺序存储的栈,也就顺序栈. 图示(来自百度图片): 顺序栈的实现: 栈的顺序存储还是比较简单的,就是对数组进行操作. <span style="font-family:Courier New;font-size:14px;">#include <iostrea

Java的顺序栈和链式栈

栈的定义 栈是限制在表的一段进行插入和删除的运算的线性表,通常能够将插入.删除的一端为栈顶,例外一端称为栈底,当表中没有任何元素的时候称为空栈. 通常删除(又称"退栈")叫做弹出pop操作,每次删除的都是栈顶最新的元素:每次插入(又称"进栈")称为压入push操作. 当栈满的时候,进行push 操作,会上溢,当空栈的时候进行退栈操作的时称为下溢. 上溢是一种出错的情况,下溢可能是正常的情况处理. 堆栈的运算是按照后进先出的原则,简称LIFO. 栈的基本运算定义: i