TShopping

 找回密碼
 註冊
搜索
查看: 1637|回復: 0
打印 上一主題 下一主題

[教學] PHP基於陣列實現的堆疊和佇列功能示例

[複製鏈接]
跳轉到指定樓層
1#
發表於 2020-8-13 22:34:35 | 只看該作者 回帖獎勵 |正序瀏覽 |閱讀模式
 
Push to Facebook
本文例項講述了PHP基於陣列實現的堆疊和佇列功能。分享給大家供大家參考,具體如下:

堆疊和佇列是資料結構的兩種實現形式,是使用非常廣泛的儲存資料的容器。下面呢,就分別講下這兩種容器在PHP中的應用:

一、使用陣列實現堆疊:

1、堆疊容器中,最後進棧的將會被最先出棧,即所謂的“先進後出”的資料結構。

2、在PHP中,將陣列當做一個棧,可使用array_push()函式或者以“$array[]=$value”完成進棧操作,使用array_pop()函式完成出棧操作。

3、堆疊的進棧操作相當於:將資料挨個放入一個桶狀的(假設資料和此桶具有恰當的表面面積,即剛好能橫放進去)容器中,造成的結果就是,完成所有資料進棧之後,先進棧的在最下面。

4、陣列進棧示例:
  1. <?php
  2. $mypara = array("para1");
  3. echo(array_push($mypara,"para2"));  //新增一個資料到mypara陣列
  4. print_r($mypara);
  5. $mypara1=array("a"=>"para11","b"=>"para12");
  6. echo array_push($mypara1,"para13","para14");
  7. print_r($mypara1);  //Array([a] => para11 [b] => para12 [0] => para13 [2] => para14)
  8. $mypara1["c"] = "para15";  //以“$array[]=$value”形式新增
  9. print_r ($mypara1); //Array([a] => para11 [b] => para12 [0] => para13 [2] => para14 [c] => para15)
  10. ?>
複製代碼



5、陣列出棧示例:
  1. <?php
  2. $mypara = array("para1","para2","para3","para4");
  3. echo array_pop($mypara); //將最後的元素返回被刪除的值彈出,輸出PHP
  4. print_r($mypara); //Array([0] => para1 [1]=>para2 [2]=>para3)
  5. ?>
複製代碼

二、使用陣列實現佇列:

1、在資料結構中,佇列和堆疊有所不同,遵循“先進先出”的原則。

2、佇列舉例理解,就好比輸液針管一樣,先進入細管的液體先進入人體。

3、在PHP中,將陣列當成一個佇列,可使用array_push()函式或者以“$array[]=$value”完成新增資料操作,使用array_shift()函式完成刪除資料操作。

4、陣列刪除佇列資料示例:
  1. <?php
  2. $mypara = array("a"=>"para1","b"=>"para2","c"=>"para3");
  3. echo array_shift($mypara);
  4. print_r($mypara);
  5. ?>
複製代碼



5、注意:PHP還提供了另外一個從佇列陣列的開頭插入一個或多個元素,該函式執行成功將返回插入元素的個數,使用格式和函式array_push()一樣。即可以使用array_unshift()函式和array_shift()函式進行佇列的操作。

 

臉書網友討論
*滑块验证:
您需要登錄後才可以回帖 登錄 | 註冊 |

本版積分規則



Archiver|手機版|小黑屋|免責聲明|TShopping

GMT+8, 2024-11-1 06:46 , Processed in 0.058984 second(s), 24 queries .

本論壇言論純屬發表者個人意見,與 TShopping綜合論壇 立場無關 如有意見侵犯了您的權益 請寫信聯絡我們。

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回復 返回頂部 返回列表