当前位置:首页 > PHP

php 实现堆栈实现

2026-02-14 06:25:23PHP

使用数组模拟堆栈

在PHP中,可以通过数组函数array_push()array_pop()实现堆栈的压入和弹出操作。堆栈遵循后进先出(LIFO)原则。

$stack = array();

// 压栈操作
array_push($stack, 'A');
array_push($stack, 'B');
array_push($stack, 'C');

// 查看堆栈内容
print_r($stack); // 输出: Array ( [0] => A [1] => B [2] => C )

// 弹栈操作
$top = array_pop($stack);
echo $top; // 输出: C
print_r($stack); // 输出: Array ( [0] => A [1] => B )

使用SplStack类

PHP标准库(SPL)提供了SplStack类专门用于堆栈操作,性能优于数组模拟。

$stack = new SplStack();

// 压栈操作
$stack->push('X');
$stack->push('Y');
$stack->push('Z');

// 查看堆栈顶部元素(不移除)
echo $stack->top(); // 输出: Z

// 弹栈操作
$popped = $stack->pop();
echo $popped; // 输出: Z

// 遍历堆栈
$stack->rewind();
while($stack->valid()) {
    echo $stack->current(), "\n";
    $stack->next();
}

手动实现堆栈类

通过面向对象方式自定义堆栈类,可以更灵活地扩展功能。

class Stack {
    private $elements = array();

    public function push($item) {
        array_push($this->elements, $item);
    }

    public function pop() {
        if ($this->isEmpty()) {
            throw new RuntimeException("Stack is empty");
        }
        return array_pop($this->elements);
    }

    public function peek() {
        return end($this->elements);
    }

    public function isEmpty() {
        return empty($this->elements);
    }

    public function size() {
        return count($this->elements);
    }
}

// 使用示例
$stack = new Stack();
$stack->push(10);
$stack->push(20);
echo $stack->pop(); // 输出: 20
echo $stack->peek(); // 输出: 10

堆栈的应用示例

实现括号匹配校验是堆栈的典型应用场景。

php 实现堆栈实现

function isBalanced($str) {
    $stack = new SplStack();
    $pairs = [ ')' => '(', '}' => '{', ']' => '[' ];

    for ($i = 0; $i < strlen($str); $i++) {
        $char = $str[$i];
        if (in_array($char, ['(', '{', '['])) {
            $stack->push($char);
        } elseif (in_array($char, [')', '}', ']'])) {
            if ($stack->isEmpty() || $stack->pop() != $pairs[$char]) {
                return false;
            }
        }
    }
    return $stack->isEmpty();
}

var_dump(isBalanced("({[]})")); // 输出: true
var_dump(isBalanced("([)]"));   // 输出: false

标签: 堆栈php
分享给朋友:

相关文章

php实现

php实现

PHP 实现的基本方法 PHP 是一种服务器端脚本语言,广泛用于 Web 开发。以下是 PHP 实现的一些常见方法。 变量与数据类型 PHP 变量以 $ 开头,支持多种数据类型: $nam…

php怎么实现登录功能

php怎么实现登录功能

数据库准备 创建用户表存储登录信息,通常包括用户名、密码(需加密)等字段。示例SQL: CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY…

php 实现下载

php 实现下载

PHP 实现文件下载的方法 使用 PHP 实现文件下载可以通过设置 HTTP 头信息,强制浏览器将文件作为附件下载而非直接打开。 基本下载实现 $file_path = 'path/to/your/…

php实现注册登录

php实现注册登录

PHP 注册功能实现 创建数据库表(以 MySQL 为例) CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, usern…

php array实现

php array实现

PHP 数组实现 PHP 数组是一种灵活的数据结构,可以存储多个值。以下是几种常见的实现方式: 索引数组 索引数组使用数字作为键名,默认从0开始递增。 $fruits = array("Apple…

php实现抽奖程序

php实现抽奖程序

PHP实现抽奖程序 基本抽奖逻辑 创建一个简单的抽奖程序需要定义奖品、中奖概率及随机选择逻辑。以下是一个基础实现示例: <?php // 奖品配置(奖品名称 => 概率) $prizes…