博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据结构与算法之PHP实现队列、栈
阅读量:5075 次
发布时间:2019-06-12

本文共 6242 字,大约阅读时间需要 20 分钟。

 
一、队列
1)队列(Queue)是一种先进先出(FIFO)的线性表,它只允许在表的前端进行删除操作,在表的后端进行插入操作,进行插入操作的端称为队尾,进行删除操作的端称为队头。即入队只能从队尾入,出队只能从队头出。
2)队列一般拥有队首(front指针)和队尾(rear指针),当一个队列并未存入数据的时候,front和rear指针均指向队首。
3)入队操作:rear后移,存入数据在rear指向的单元,队满不可入队,这同时也表明front总是指向队首元素的前驱。
4)出队操作:front后移,元素出队,队空不可出队。
5)在PHP函数中,array_push函数是向数组尾部添加元素,即入队操作;array_shift函数是删除数组头部元素,即出队操作。
$array =  array('a', 'b');
array_push($array, 'c'); //入队
array_shift($array);     //出队
队列的数组实现
dataStore); } // 判断队列是否为空 public function isEmpty() { return $this->getLength() === 0; } // 入队,在队尾加入数据。 public function enqueue($element) { $this->dataStore[] = $element; // array_push($this->dataStore, $element); } // 出队,返回并移除队首数据。队空不可出队。 public function dequeue() { if (!$this->isEmpty()) { return array_shift($this->dataStore); } return false; } // 遍历队列,并输出 public function show() { if (!$this->isEmpty()) { for ($i = 0; $i < $this->getLength(); $i++) { echo $this->dataStore[$i] . PHP_EOL; } } else { return "空"; } } // 清空队列 public function clearQueue() { unset($this->dataStore); // $this->dataStore = array(); }}// 测试$q = new Queue();$q->enqueue('a');$q->enqueue('b');$q->enqueue('c');echo '队列的长度为:' . $q->getLength();echo "
";echo '队列为:';$q->show();echo "
";$q->dequeue();echo "
";echo "a出队,队列为:";$q->show();$q->clearQueue();echo "清空队列后,队列为" . $q->show();复制代码
View Code

队列的链表实现

创建链式队列时,需定义两个结构,一个用于描述节点,一个用于描述队列。
data = $data; $this->next = NULL; }}// 队列类class Queue { private $header; // 头节点 function __construct($data) { $this->header = new Node($data); } // 判断队列是否为空 public function isEmpty() { if ($this->header->next !== null) { // 不为空 return false; } return true; } // 入队,在队尾加入数据。 public function enqueue($element) { $newNode = new Node($element); $current = $this->header; if ($current->next == null) { // 只有头节点 $this->header->next = $newNode; } else { // 遍历到队尾最后一个元素 while ($current->next != null) { $current = $current->next; } $current->next = $newNode; } $newNode->next = null; } // 出队,返回并移除队首数据。队空不可出队。 public function dequeue() { if ($this->isEmpty()) { // 队列为空 return false; } // header头节点没有实际意义,队首节点是header指向的结点。 $current = $this->header; $current->next = $current->next->next; } // 清空队列 public function clear() { $this->header = null; } // 显示队列中的元素 public function show() { $current = $this->header; if ($this->isEmpty()) { echo "空!"; } while ($current->next != null) { echo $current->next->data . PHP_EOL; $current = $current->next; } }}// 测试$q = new Queue('header');$q->enqueue('a');$q->enqueue('b');$q->enqueue('c');echo "队列为:";$q->show();echo "
";echo "a出队,队列为:";$q->dequeue();$q->show();echo "
";$q->clear();echo "清空队列后,队列为";$q->show();复制代码
View Code
二、栈
1)栈(Stack)是一种后进先出(LIFO)表,插入删除操作都只能在一个位置上进表,这个位置位于表的末端,叫做栈顶(Top),另一端则称为栈底(Bottom),又称为表头。
2)对栈的基本操作有push和pop,表示进栈和出栈,相当于插入和删除操作。存储数据时,先进入的数据被压入栈底,后进入的数据则在栈顶;读取数据时,从栈顶开始弹出数据。
3)在PHP函数中,array_push函数是向数组尾部添加元素,即入栈操作;array_pop函数是删除数组尾部元素,即出栈操作。
$array =  array('a', 'b');
array_push($array, 'c'); //入栈
array_pop($array);       //出栈
栈的数组实现
选择用数组表示栈内容必须预先估计栈的最大容量。因为数组一旦创建,其大小是无法改变的,而数组设置过大可能会浪费大量内存,设置过小又可能会溢出。
stack); } // 入栈,在最顶层加入数据。 public function push($element) { $this->stack[] = $element; } // 出栈,返回并移除最顶层的数据。 public function pop() { if ($this->getLength() > 0) { return array_pop($this->stack); } } // 返回最顶层数据的值,但不移除它 public function getTop() { $top = $this->getLength() - 1; return $this->stack[$top]; } // 清空栈 public function clearStack() { unset($this->stack); // $this->stack = array(); } // 遍历栈元素 public function show() { if ($this->getLength() > 0) { for ($i = 0; $i < $this->getLength(); $i++) { echo $this->stack[$i] . PHP_EOL; } } echo "空!"; }}// 测试$s = new Stack();$s->push('a');$s->push('b');$s->push('c');echo "栈为:";$s->show();echo "
";echo '栈顶元素为' . $s->getTop();echo "
";echo '栈的长度为:' . $s->getLength();echo "
";$s->pop();echo "出栈,弹出c,栈为:";$s->show();echo "
";echo "清空栈,栈为:";$s->clearStack();$s->show();
View Code

栈的链表实现

data = $data; $this->next = NULL; }}class Stack { private $header; // 头节点 function __construct($data) { $this->header = new Node($data); } // 判断栈是否为空 public function isEmpty() { if ($this->header->next !== null) { // 不为空 return false; } return true; } // 入栈,插入新的栈顶节点 public function push($element) { $newNode = new Node($element); $current = $this->header; if ($current->next == null) { // 只有头节点 $this->header->next = $newNode; } else { // 遍历到栈尾最后一个元素 while ($current->next != null) { $current = $current->next; } $current->next = $newNode; } $newNode->next = null; } // 出栈,删除栈顶元素 public function pop() { if ($this->isEmpty()) { // 栈为空 return false; } $current = $this->header; while ($current->next->next != null) { $current = $current->next; } $current->next = null; } // 清空栈 public function clear() { $this->header = null; } // 显示栈中的元素 public function show() { $current = $this->header; if ($this->isEmpty()) { echo "空!"; } while ($current->next != null) { echo $current->next->data . PHP_EOL; $current = $current->next; } }}// 测试$s = new Stack('header');$s->push('a');$s->push('b');$s->push('c');echo "栈为:";$s->show();echo "
";$s->pop();echo "出栈,弹出c,栈为:";$s->show();echo "
";echo "清空栈,栈为:";$s->clear();$s->show();
View Code

原文:https://www.cnblogs.com/sunshineliulu/p/7740102.html

转载于:https://www.cnblogs.com/ivy-zheng/p/10937606.html

你可能感兴趣的文章
正则表达式(进阶篇)
查看>>
无人值守安装linux系统
查看>>
【传道】中国首部淘宝卖家演讲公开课:农业本该如此
查看>>
jQuery应用 代码片段
查看>>
MVC+Servlet+mysql+jsp读取数据库信息
查看>>
黑马程序员——2 注释
查看>>
用OGRE1.74搭建游戏框架(三)--加入人物控制和场景
查看>>
转化课-计算机基础及上网过程
查看>>
android dialog使用自定义布局 设置窗体大小位置
查看>>
ionic2+ 基础
查看>>
互联网模式下我们更加应该“专注”
查看>>
myeclipse集成jdk、tomcat8、maven、svn
查看>>
查询消除重复行
查看>>
Sand Making Plant Produced by Red Star
查看>>
Win 10 文件浏览器无法打开
查看>>
HDU 1212 Big Number(C++ 大数取模)(java 大数类运用)
查看>>
-bash: xx: command not found 在有yum源情况下处理
查看>>
[leetcode]Minimum Path Sum
查看>>
内存管理 浅析 内存管理/内存优化技巧
查看>>
hiho1079 线段树区间改动离散化
查看>>