+
95
-

回答

内置的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;
}


网友回复

我知道答案,我要回答