這篇文章給大家分享的是有關PHP如何實現棧數據結構的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

具體如下:
利用php面向對象思想,棧的屬性有top、較大存儲數、和存儲容器(這里利用了php數組)。
代碼如下:實現了入棧、出棧、遍歷棧的幾個方法:
<?php
class Stack{
const MAXSIZE = 4;// 棧較大容量
private $top = -1;
private $stack = array();// 利用數組存儲數據
public function __construct(){
$this->stack = array();
}
// 入棧
public function push($ele){
if ($this->top >= self::MAXSIZE-1){
echo 'stack is full...';
return false;
}
$this->stack[++$this->top] = $ele;// 此處必須是++i,先計算再使用
}
// 出棧,返回出棧元素
public function pop(){
if ($this->top == -1){
echo 'stack is empty...';
return false;
}
$ele = $this->stack[$this->top];
unset($this->stack[$this->top--]);// 此處必須是i--,先使用再計算(注意出棧和入棧的區(qū)別)
return $ele;
}
// 遍歷棧
public function show(){
if ($this->top == -1){
echo 'stack is empty...';
return false;
}
for($i=$this->top; $i>-1; $i--){
echo $this->stack[$i].'<br/>';
}
}
}
$stack = new Stack;
$stack->push(1);
$stack->push(2);
$stack->push(3);
$stack->push(4);
//print_r($stack);
$stack->show();
$a = $stack->pop();
$a = $stack->pop();
$a = $stack->pop();
$stack->show();運行結果:
4 3 2 1 1
感謝各位的閱讀!關于“PHP如何實現棧數據結構”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
當前名稱:PHP如何實現棧數據結構-創(chuàng)新互聯
文章路徑:http://www.chinadenli.net/article40/deejho.html
成都網站建設公司_創(chuàng)新互聯,為您提供品牌網站設計、網站改版、云服務器、網站內鏈、外貿網站建設、網站制作
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯