PHP如何通过带尾指针的链表实现'队列'
这篇文章是展示通过 PHP
语言实现一种带 尾指针
的链表,然后通过链表来实现队列,其中链表的头元素 head
是用于列队 出队
的,它的时间复杂度 O(1)
,若在 head
的基础上实现链表尾部 入队
时间度为 O(n),为了降低入队操作的时间复杂度,可以给链表维护一个带有尾指针的变量 tail
,这样每次入队的时候直接操作 tail
,出队的时候直接操作 head
,这样可以使得 入队
和 出队
时间复杂度都是 O(1)。
1.output_queue_by_liked_list.php
这是一个演示打印输出结果的文件:
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | <?php require 'QueueByLinkedList.php' ; $queue = new QueueByLinkedList(); $queue ->enqueue( "rr" ); //入队 $queue ->enqueue( "tt" ); //入队 $queue ->enqueue( "yy" ); //入队 $queue ->enqueue( "uu" ); //入队 $queue ->enqueue( "ii" ); //入队 $queue ->enqueue( "oo" ); //入队 echo $queue ->toString(); //打印 rr->tt->yy->uu->ii->oo->null echo "<br>" ; echo $queue ->dequeue(); //出队 打印 rr echo "<br>" ; echo $queue ->dequeue(); //出队 打印 tt echo "<br>" ; echo $queue ->dequeue(); //出队 打印 yy echo "<br>" ; echo $queue ->toString(); //打印 uu->ii->oo->null echo "<br>" ; $queue ->enqueue( "11" ); //入队 $queue ->enqueue( "22" ); //入队 $queue ->enqueue( "33" ); //入队 $queue ->enqueue( "44" ); //入队 $queue ->enqueue( "55" ); //入队 $queue ->enqueue( "66" ); //入队 echo "<br>" ; echo $queue ->toString(); //打印 uu->ii->oo->11->22->33->44->55->66->null |
2.QueueByLinkedList 类
这是通过带尾指针链表实现的 队列
类,它里面有 入队(enqueue)
方法和 出队(dequque)
方法 :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 | <?php require 'Queue.php' ; /** * 带有尾指针的链表 * Class LinkedListTail */ class QueueByLinkedList implements Queue { private $head ; //链表头部 private $tail ; //链表尾部 private $size ; //链表大小 /** * 构造函数 初始化链表 * QueueByLinkedList constructor. */ public function __construct() { $this ->head = null; $this ->tail = null; $this ->size = 0; } /** * 入队操作 * @param $e */ public function enqueue( $e ): void { if ( $this ->tail == null) { $this ->tail = $this ->head = new Node( $e , null); } else { $node = new Node( $e , null); $this ->tail->next = $node ; $this ->tail = $node ; } $this ->size++; } /** * 出队操作 * @return mixed */ public function dequeue() { if ( $this ->size == 0) { return "队列已经是空的" ; } $node = $this ->head; $this ->head = $node ->next; $this ->size--; if ( $node ->next == null) { $this ->tail = null; } return $node ->e; } public function getFront() { if ( $this ->size == 0) { return "队列已经是空的" ; } return $this ->head->e; } public function getSize() { return $this ->size; } /** * 判断队列是否为空 * @return bool */ public function isEmpty(): bool { return $this ->size == 0; } public function toString() { $str = "" ; for ( $node = $this ->head; $node != null; $node = $node ->next) { $str .= $node ->e . "->" ; } $str .= "null" ; return $str ; } } class Node { public $e ; //节点元素 public $next ; //下个节点信息 /** * 构造函数 设置节点信息 * Node constructor. * @param $e * @param $next */ public function __construct( $e , $next ) { $this ->e = $e ; $this ->next = $next ; } } |
3.interface Queue
这里是 队列
类一个实现接口,里面定义了一些函数,继承它之后,必须重构里面的所有方法:
1 2 3 4 5 6 7 8 9 | <?php interface Queue { public function enqueue( $e ): void; //入队 public function dequeue(); //出队 public function getFront(); //获取前端元素 public function getSize(); //获取队列大小 public function isEmpty(); //判断队列是否为空 } |
以上就是PHP如何通过带尾指针的链表实现'队列'的详细内容,更多关于PHP 实现队列的资料请关注服务器之家其它相关文章!
原文链接:https://segmentfault.com/a/1190000037557689?utm_source=tuicool&utm_medium=referral
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。