普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头取出。在优先队列中,元素被赋予优先级。当访问元素时,具有最高优先级的元素最先取出。优先队列具有最高级先出 (largest-in,first-out)的行为特征。

总结下来就是普通队列有先进先出原则,优先级队列有优先级高先出原则,这个优先级可以设置;

类摘要

// 1. 没有实现ArrayAccess接口,所以不能像数组那样操作;
SplPriorityQueue implements Iterator , Countable {
/* 方法 */
public __construct ( void ) // 比较方法,内部应该用到了冒泡排序,对于权重值来说,返回0代表相等,返回正整数就代表大于,返回负整数就代表小于;
// 默认是权重值越优先,也可以让其被子类覆盖改为权重值越小越优先
public int compare ( mixed $priority1 , mixed $priority2 )
public mixed extract ( void ) //恢复到上一个被破坏的节点? 测试无用;
public void recoverFromCorruption ( void )
public void setExtractFlags ( int $flags )
public void insert ( mixed $value , mixed $priority ) public int count ( void )
public mixed current ( void )
public bool isEmpty ( void )
public mixed key ( void )
public void next ( void )
public void rewind ( void )
public mixed top ( void )
public bool valid ( void )
}

Example

class PQtest extends SplPriorityQueue
{
//覆盖父类,更改其优先规则为权重值越小越优先;
public function compare($priority1, $priority2)
{
if ($priority1 === $priority2) return 0;
return $priority1 > $priority2 ? -1 : 1;
}
} $pq = new PQtest(); // 设置值与优先值
$pq->insert('a', 10);
$pq->insert('b', 1);
$pq->insert('c', 8); /**
* 设置元素出队模式
* SplPriorityQueue::EXTR_DATA 仅提取值
* SplPriorityQueue::EXTR_PRIORITY 仅提取优先级
* SplPriorityQueue::EXTR_BOTH 提取数组包含值和优先级
*/
$pq->setExtractFlags(PQtest::EXTR_BOTH); //从顶部取出一个节点,该节点下面的节点移上为顶部节点;
print_r(
$pq->extract()
);
/*
[data] => b
[priority] => 1
*/ $pq->recoverFromCorruption(); //拿出顶部节点
print_r(
$pq->extract()
); /*
[data] => c
[priority] => 8
*/ // 还原自上一个节点? 没什么效果?
$pq->recoverFromCorruption(); print_r(
$pq->current()
); $pq->rewind();
while($pq->valid()){
print_r($pq->current());
echo PHP_EOL;
$pq -> next();
}

最新文章

  1. Google 地图 API V3 之 叠加层
  2. Web设计师值得收藏的10个jQuery特效
  3. 两个不等式(Nopier)
  4. PLSQL_数据泵导入进度查看Impdp/Expdp Status(案例)
  5. jQuery刷新div内容,并对刷新后元素绑定事件。$(document).on()
  6. Tomcat启动后访问首页报错 显示JSP 空指针异常
  7. uboot环境变量区为何不能放在data段
  8. python IDE ulipad配置使用
  9. CodeForces Round #191 (327C) - Magic Five 等比数列求和的快速幂取模
  10. 用node探究http缓存
  11. PHP安装swoole扩展
  12. 长短steamId互转
  13. Java基础-对象的内存分配与初始化(一定要明白的干货)
  14. 使用log4net将C#日志发送到Elasticsearch
  15. 《F4+2》—团队项目系统设计改进与详细设计
  16. mysql 注入基础知识
  17. 【BZOJ】1355 [Baltic2009]Radio Transmission
  18. HTTP协议的重新学习
  19. spring boot 使用拦截器,注解 实现 权限过滤
  20. 多线程 读写锁SRWLock

热门文章

  1. 开启curl函数功能
  2. Java程序读取Properties文件
  3. 【胡思乱想】JNI与线程池的维护
  4. Apache运维中常用功能配置笔记梳理
  5. 页面出现Incorrect string以及数据库内容乱码
  6. [开源] .NET数据库ORM类库 Insql
  7. 邂逅jQuery
  8. java通过url在线预览Word、excel、ppt、pdf、txt文档
  9. 使用nginx+tomcat将所有请求都转发到一个页面
  10. Linux常用基本命令(head)