当前位置:首页 > PHP

php 栈的实现

2026-02-15 17:08:44PHP

栈的基本概念

栈是一种遵循后进先出(LIFO)原则的数据结构,只允许在栈顶进行插入(push)和删除(pop)操作。栈的实现通常基于数组或链表。

php  栈的实现

基于数组的栈实现

使用数组实现栈时,需维护一个指针(或索引)指向栈顶元素。以下是PHP代码示例:

php  栈的实现

class Stack {
    private $stack;
    private $top;

    public function __construct() {
        $this->stack = array();
        $this->top = -1;
    }

    public function push($value) {
        $this->top++;
        $this->stack[$this->top] = $value;
    }

    public function pop() {
        if ($this->isEmpty()) {
            return null;
        }
        $value = $this->stack[$this->top];
        unset($this->stack[$this->top]);
        $this->top--;
        return $value;
    }

    public function peek() {
        if ($this->isEmpty()) {
            return null;
        }
        return $this->stack[$this->top];
    }

    public function isEmpty() {
        return $this->top === -1;
    }

    public function size() {
        return $this->top + 1;
    }
}

基于链表的栈实现

链表实现的栈更灵活,动态分配内存。以下是PHP代码示例:

class Node {
    public $data;
    public $next;

    public function __construct($data) {
        $this->data = $data;
        $this->next = null;
    }
}

class LinkedListStack {
    private $top;

    public function __construct() {
        $this->top = null;
    }

    public function push($value) {
        $newNode = new Node($value);
        $newNode->next = $this->top;
        $this->top = $newNode;
    }

    public function pop() {
        if ($this->isEmpty()) {
            return null;
        }
        $value = $this->top->data;
        $this->top = $this->top->next;
        return $value;
    }

    public function peek() {
        if ($this->isEmpty()) {
            return null;
        }
        return $this->top->data;
    }

    public function isEmpty() {
        return $this->top === null;
    }
}

栈的常见操作

  • push($value):将元素压入栈顶。
  • pop():移除并返回栈顶元素。
  • peek():返回栈顶元素但不移除。
  • isEmpty():检查栈是否为空。
  • size():返回栈中元素数量(仅数组实现需要)。

注意事项

  • 数组实现的栈需注意数组越界问题。
  • 链表实现的栈需注意内存管理,避免内存泄漏。
  • PHP数组本身具备动态扩容特性,简化了数组实现的边界处理。

以上实现可根据实际需求扩展,例如添加异常处理或支持泛型数据。

标签: php
分享给朋友:

相关文章

php实现验证码

php实现验证码

PHP实现验证码的方法 使用GD库生成验证码 GD库是PHP中处理图像的扩展,可用于生成验证码图片。 <?php session_start(); $width = 120; $height…

php 实现购物车

php 实现购物车

PHP 实现购物车功能 购物车功能是电子商务网站的核心部分,可以通过 PHP 和 Session 或数据库来实现。以下是两种常见的实现方式: 使用 Session 存储购物车数据 Session 是…

php 实现文件下载

php 实现文件下载

实现文件下载的基本方法 使用 PHP 实现文件下载的核心是通过设置 HTTP 头部信息,强制浏览器将文件作为附件下载而非直接显示。以下是一个基础实现示例: $file_path = '/path/t…

php实现静态

php实现静态

静态化实现方法 PHP实现静态化主要通过生成HTML文件或缓存机制来减少服务器动态解析的开销。以下是几种常见方法: 生成静态HTML文件 通过file_put_contents()将动态内容保存为H…

php实现博客

php实现博客

使用PHP实现博客系统 数据库设计 创建数据库表存储博客文章和用户信息。常见的表包括posts(文章)和users(用户)。 CREATE TABLE users ( id INT AUTO…

php 实现类

php 实现类

PHP 类的基本实现 在 PHP 中,类通过 class 关键字定义,后跟类名和一对花括号。类名通常遵循大驼峰命名法(如 ClassName)。以下是基本语法: class ClassName {…