数据结构之栈——顺序存储结构(php代码实现)

<?php
/**
    1. DestroyStack(): 栈的销毁
    2. ClearStack(): 将栈置为空栈
    3. StackEmpty(): 判断栈是否为空
    4. StackLength(): 返回栈的长度
    5. GetTop(): 取得栈顶的元素
    6. Push(): 插入新的栈顶元素
    7. Pop(): 删除栈顶元素
    8. StackTraverse(): 遍历栈元素
 */

//除了push和pop方法外,其余的方法和之前线性表的顺序存储的代码实现基本相同

class SqStack{
    public $SqArr;//此处是用于存储栈元素的数组
    private  $top; //表示栈顶,相当于数组的最后一个元素下标
    public function __construct($SqArr){
        $this->SqArr=$SqArr;
        $this->top=count($SqArr)-1;
    }

    //栈的销毁
    public function DestroyStack(){
        $this->SqArr=null;
        $this->top=-1;
    }

    //将栈置为空栈
    public function ClearStack(){
        $this->SqArr=array();
        $this->top=-1;
    }

    //判断栈是否为空
    public function StackEmpty(){
        if($this->top==-1){
            return ‘Null‘;
        }else{
            return ‘No Null‘;
        }
    }

    //返回栈的长度
    public function StackLength(){
        if(is_null($this->SqArr)){
            return null;
        }
        return $this->top+1;
    }

    //取得栈顶的元素
    public function GetTop(){
        if($this->top==-1){
            return ‘ERROR‘;
        }
        return $this->SqArr[$this->top];
    }

    //插入新的栈顶元素
    public function Push($elem){
        $this->top++;
        $this->SqArr[$this->top]=$elem;
    }

    //删除栈顶元素
    public function Pop(){
        if($this->top==-1){
            return ‘ERROR‘;
        }
        $p=$this->SqArr[$this->top];
        unset($this->SqArr[$this->top]);
        //注,此句可以有也可以没有,如果此语句存在,则在堆栈内存中会将此栈顶元素真正的删除;倘若没有此语句,则仅仅是top指针不在指向此栈顶元素了。另外,此语句有没有对应的下面的遍历方法的实现也不同,没有则对应StackTraverse()方法,有则对应StackTraverse2()方法。
        
        $this->top--;
        return $p;
    }

    //遍历栈元素
    public function StackTraverse(){
        if(is_null($this->SqArr)){
            return null;
        }
        $arr=array();
        for($i=0;$i<=$this->top;$i++){
            $arr[]=$this->SqArr[$i];
        }
        return $arr;
    }
    public function StackTraverse2(){
        return $this->SqArr;
    }
}
时间: 2024-08-07 10:18:35

数据结构之栈——顺序存储结构(php代码实现)的相关文章

一步一步学习数据结构(三)栈的顺序存储结构实现代码

//栈这种逻辑结构的实现与一般线性表的实现类似,有两种存储方式:顺序存储和链式存储 //先学习顺序存储 //1. #include<stdio.h> #include<stdlib.h> #define null NULL #define SIZE 100 typedef int dataType ; typedef struct { dataType data[SIZE]; int top; }cStack,*cStackPointer; //初始化栈空间 void initSt

数据结构(03)_顺序存储结构线性表

本节我们基于前面实现的数据结构类模板基础,继续完成基于顺序存储结构的线性表的实现,话不多说,继承关系图如下: 14.线性表的本质和操作 14.1.线性表的表现形式 零个多多个数据元素组成的集合 数据元素在位置上是有序排列的 数据元素的个数是有限的 数据元素的类型必须相同 14.2.线性表的抽象定义.性质 线性表是具有相同类型的n(>=)个数据元素的有限序列,(a0, a1, a2... an-1),其中ai是表项,n是表长度.性质: a0为线性表的第一个元素,只有一个后继 an-1为线性表的最后

数据结构——线性表顺序存储结构

 关于线性表 线性表是零个或者多个数据元素的集合.它主要有以下三个特征: 1:线性表的数据元素之间是有顺序的. 2:线性表中数据元素个数是有限的. 3:线性表中数据元素数据类型是相同的. 关于线性表的操作,主要有 创建线性表.销毁线性表.清空线性表.将元素插入线性表.将元素从线性表中删除.获取线性表中某个位置的元素.获取线性表的长度. 线性表主要有两种存储结构: 1:线性表的顺序存储结构,c语言中的数组及采用这种方式. 2:线性表的链式存储结构. 关于顺序存储结构 定义: 是指用一段地址连续的内

数据结构 - 线性表顺序存储结构

线性表 线性表是一种典型的线性结构.其基本特点是线性表中的数据元素是有序且是有限的.在这种结构中: ① 存在一个唯一的被称为"第一个"的数据元素: ② 存在一个唯一的被称为"最后一个"的数据元素: ③ 除第一个元素外,每个元素均有唯一一个直接前驱: ④ 除最后一个元素外,每个元素均有唯一一个直接后继. 线性表(Linear List) :是由n(n≧0)个数据元素(结点)a1,a2, -an组成的有限序列.该序列中的所有结点具有相同的数据类型. 线性表中的数据元素

数据结构 - 队列静态顺序存储结构

队列的基本概念 1 队列的基本概念 队列(Queue):也是运算受限的线性表.是一种先进先出(First In First Out ,简称FIFO)的线性表.只允许在表的一端进行插入,而在另一端进行删除. 队首(front) :允许进行删除的一端称为队首. 队尾(rear) :允许进行插入的一端称为队尾. 例如:排队购物.操作系统中的作业排队.先进入队列的成员总是先离开队列. 队列中没有元素时称为空队列.在空队列中依次加入元素a1, a2, -, an之后,a1是队首元素,an是队尾元素.显然退

数据结构|-完全二叉树的顺序存储结构的实现

对于一个完全二叉树,假设它有n个结点,对结点进行从1开始编号,对任一结点i满足下面 它的双亲是结点 i/2 (除了i=1的情况) 左孩子是 2i 右孩子是 2i+1 如果2i>n 说明无左孩子 2i+1>n 说明无右孩子 一般的树来说是一对多的关系,使用顺序结构存储起来比较困难,但是二叉树是一种特殊的树,每个结点最多有两个子节点,并且子节点有左右之分,并且兄弟,父亲,孩子可以很方便的通过编号得到,所以我们使用顺序存储结构使用二叉树的存储. using System; using System.

数据结构之完全二叉树——顺序存储结构(php代码实现)

<?php /**  * 二叉树的顺序结构的实现比较适合实现完全二叉树和满二叉树.  * 我们可以使用数组来存储二叉树每个结点的数据元素,使用数组  * 下标表示结点之间的关系,根据完全(满)二叉树的定义,结点间的关系如下:  *      1.第i层上,结点序号范围是pow(2,i-1)-1--pow(2,i)-2:  *      2.k层的完全(满)二叉树最多有pow(2,k)-1个结点:  *      3.序号为i的结点,其双亲节点的序号为(i+1)/2-1:  *      4.序号

数据结构之队列——顺序存储结构(php代码实现——方法一)

<?php /**  * 第一种--非循环顺序队列的实现方法  * 队列的头元素在为数组的下标为0的元素  * 这种方法的优缺点:  *  优点:头元素始终在下标为 0 的第一个元素,因此不需要设置头指针  *  缺点:元素出队是会移动大量元素,时间复杂度为O(n),效率比较低  *  */ class SqQueue{     private $SqArr;//队列存储数组     private $rear;//若队列不为空,则指向队尾元素的后一个位置     public function

数据结构---线性表---顺序存储结构

头文件 header.h #ifndef _LIST_H #define _LIST_H #include <stdio.h> #include <stdlib.h> #include <memory.h> #define MY_TYPE int /*0:int 1:double 2:float 3:char*/ #define _MY_TYPE_ 0 #define LIST_INIT_SIZE 3 /*单位:MY_TYPE*/ #define LIST_INCRE_