加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使

发布时间:2020-12-13 02:36:47 所属栏目:PHP教程 来源:网络整理
导读:《:PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例》要点: 本文介绍了:PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例,希望对您有用。如果有疑问,可以联系我们。 队列这种数据结构更简单,就像我们生活中排

《:PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例》要点:
本文介绍了:PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例,希望对您有用。如果有疑问,可以联系我们。

队列这种数据结构更简单,就像我们生活中排队一样,它的特性是先进先出(FIFO).PHP教程

:PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例PHP教程

PHP SPL中SplQueue类就是实现队列操作,和栈一样,它也可以继承双链表(SplDoublyLinkedList)轻松实现.
SplQueue类摘要如下:PHP教程

:PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例PHP教程

SplQueue简单使用如下:PHP教程

代码如下:

$queue = new SplQueue();
?
/**
?* 可见队列和双链表的区别就是IteratorMode改变了罢了,栈的IteratorMode只能为:
?* (1)SplDoublyLinkedList::IT_MODE_FIFO | SplDoublyLinkedList::IT_MODE_KEEP? (默认值,迭代后数据保存)
?* (2)SplDoublyLinkedList::IT_MODE_FIFO | SplDoublyLinkedList::IT_MODE_DELETE (迭代后数据删除)
?*/
$queue->setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO | SplDoublyLinkedList::IT_MODE_DELETE);
?
//SplQueue::enqueue()其实就是 SplDoublyLinkedList::push()
$queue->enqueue('a');
$queue->enqueue('b');
$queue->enqueue('c');
?
//SplQueue::dequeue()其实就是 SplDoublyLinkedList::shift()
print_r($queue->dequeue());
?
foreach($queue as $item) {
??? echo $item . PHP_EOL;
}
?
print_r($queue);

而优先队列SplPriorityQueue是基于堆(后文介绍)实现的.
SplPriorityQueue的类摘要如下:PHP教程

:PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例PHP教程

SplPriorityQueue简单使用:PHP教程

$pq = new SplPriorityQueue();
 
$pq->insert('a',10);
$pq->insert('b',1);
$pq->insert('c',8);
 
echo $pq->count() .PHP_EOL; //3
echo $pq->current() . PHP_EOL; //a
 
/**
 * 设置元素出队模式
 * SplPriorityQueue::EXTR_DATA 仅提取值
 * SplPriorityQueue::EXTR_PRIORITY 仅提取优先级
 * SplPriorityQueue::EXTR_BOTH 提取数组包括值和优先级
 */
$pq->setExtractFlags(SplPriorityQueue::EXTR_DATA);
 
while($pq->valid()) {
  print_r($pq->current()); //a c b
  $pq->next();
}

编程之家培训学院每天发布《:PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读