内置的php类型没有堆栈,可以自定义个堆栈类来实现,代码如下:
<?php
/**
* 节点信息
*/
class node {
public $value; // 节点的数据
function __construct($value) {
$this->value = $value;
}
}
/**
*堆栈的实现
*/
class stack {
public $last; //指向尾部元素
public $stacklist; // 堆栈元素列表
public $size = 0; //队列节点个数
//出栈
function pop() {
if (0 == $this->size) {
return;
exit('the stack is empty!');
}
$data = $this->last;
array_pop($this->stacklist);
$this->last = end($this->stacklist);
$this->size--;
return $data;
}
// 入栈
function push($value) {
$node = new node($value);
$this->last = $node;
$this->stacklist[] = $node;
$this->size++;
}
//返回栈顶元素,但是不出栈
function end() {
if ($this->size > 0) {
return end($this->stacklist)->value;
}
return false;
}
function size() {
return $this->size;
}
}
$stack = new stack();
for ($i = 0; $i < 10; $i++) {
$stack->push($i);
}
while ($node = $stack->pop()) {
echo $node->value,
PHP_EOL;
}
网友回复
python如何实现torrent的服务端进行文件分发p2p下载?
如何在浏览器中录制摄像头和麦克风数据为mp4视频保存下载本地?
go如何编写一个类似docker的linux的虚拟容器?
python如何写一个bittorrent的种子下载客户端?
ai能通过看一个网页的交互过程视频自主模仿复制网页编写代码吗?
ai先写功能代码通过chrome mcp来进行测试功能最后ai美化页面这个流程能行吗?
vue在手机端上下拖拽元素的时候如何禁止父元素及body的滚动导致无法拖拽完成?
使用tailwindcss如何去掉响应式自适应?
有没有直接在浏览器中运行的离线linux系统?
nginx如何保留post或get数据进行url重定向?