算法学习笔记之——priority queue、heapsort、symbol table、binary search trees
Priority Queue
类似一个Queue,但是按照priority的大小顺序来出队
一般存在两种方式来实施
- 排序法(ordered),在元素入队时即进行排序,这样插入操作为O(N),但出队为O(1)
- 不排序法(unordered),元素直接插入到后面,出队时先排序后提取,插入操作为O(1),出队为O(N)
采用二叉树
用队列模拟二叉树,root为a[1],子元素为a[2k]或a[2k+1]
父元素总是比子元素要大,提取max为a[1]
不符合规则的子元素(其value比父元素大)可以不断与父元素交换,直至符合要求;不符合规则的父元素(其value比子元素小)可不断与子元素中最大的元素交换,直至符合要求
插入操作:将元素插入到树的右下角,然后保证该元素符合要求
删除操作:将root与最后的元素对换,提出root,再将新的root规则化(下移)直至符合要求
删除与插入都是O(lg(N))
应用实例:基于事件的仿真(Event driven simulation)
堆排序(heapsort)
1. 将数组视为完全二叉树
2. 将二叉树从底往上构建maxheap,最终二叉树满足父元素不小于子元素
3. 将根元素(最大值)与最后的元素交换,并根元素出队(array的size-1),并将新的root下沉至符合要求
4. 重复3的操作直至根元素,即完成从小到大的排列
堆排序的操作时间与内存消耗都是角优的,为O(lg(N)),但是操作时间还是小于quicksort,而且排序是不稳定的(not stable)
符号表(symbol table)
Symbol table stores the information related about the symbol.
符号表将符号与其值对应起来,可以通过符号获取与更新其值,例如传递URL到DNS服务器来获取IP地址。
public class ST<Key extends Comparable<Key>, Value>
--------------------------------------------------------
ST() create an ordered symbol table
void put(Key key, Value val) put key-value pair into the table
Value get(Key key) value paired with key
void delete(Key key) remove key (and its value) from table
boolean contains(Key key) is there a value paired with key?
boolean isEmpty() is the table empty?
int size() number of key-value pairs
Key min() smallest key
Key max() largest key
Key floor(Key key) largest key less than or equal to key
Key ceiling(Key key) smallest key greater than or equal to key
int rank(Key key) number of keys less than key
Key select(int k) key of rank k
void deleteMin() delete smallest key
void deleteMax() delete largest key
int size(Key lo, Key hi) number of keys in [lo..hi]
Iterable<Key> keys(Key lo, Key hi) keys in [lo..hi], in sorted order
Iterable<Key> keys() all keys in the table, in sorted order
| implementation | search(GAC) | insert(GAC) | search(AVC) | insert(AVC) | ordered ops? | operations on keys |
|---|---|---|---|---|---|---|
| sequential search(unordered list) | N | N | N/2 | N | no | equals() |
| binary search (ordered array) | lg(N) | N | lg(N) | N/2 | yes | compareTo() |
| BST | N | N | 1.39lg(N) | 1.39lg(N) | next | compareTo() |
GAC: Guarantee average case
AVC: Average case
BST: Binary search trees
二叉排序树BST(Binary search trees)
一个BST要么为空,要么同时有左子树与右子数,字数可以为null
每个节点的key大于所有左子树元素,但是小于所有右子树的元素
插入操作程序如下,通过递归返回更新的子树来代替原来的树
public void put(Key key, Value val){
root = put(root, key, val); }
private Node put(Node x, Key key, Value val){
if (x == null) return new Node(key, val);
int cmp = key.compareTo(x.key);
if (cmp < 0)
x.left = put(x.left, key, val);
else if (cmp > 0)
x.right = put(x.right, key, val);
else if (cmp == 0)
x.val = val;
return x;
}
BST的各种操作(search/insert/min/max/floor/ceiling/rank/select)用时都正比于数的高度
删除操作程序如下,操作用时为 \(\sqrt{N}\)
public void delete(Key key){
root = delete(root, key); }
private Node delete(Node x, Key key) {
if (x == null) return null;
int cmp = key.compareTo(x.key);
if (cmp < 0) x.left = delete(x.left, key);
else if (cmp > 0) x.right = delete(x.right, key);
else {
if (x.right == null) return x.left;
if (x.left == null) return x.right;
Node t = x;
x = min(t.right);
x.right = deleteMin(t.right);
x.left = t.left;
}
x.count = size(x.left) + size(x.right) + 1;
return x;
}
算法学习笔记之——priority queue、heapsort、symbol table、binary search trees的更多相关文章
- Johnson 全源最短路径算法学习笔记
Johnson 全源最短路径算法学习笔记 如果你希望得到带互动的极简文字体验,请点这里 我们来学习johnson Johnson 算法是一种在边加权有向图中找到所有顶点对之间最短路径的方法.它允许一些 ...
- C / C++算法学习笔记(8)-SHELL排序
原始地址:C / C++算法学习笔记(8)-SHELL排序 基本思想 先取一个小于n的整数d1作为第一个增量(gap),把文件的全部记录分成d1个组.所有距离为dl的倍数的记录放在同一个组中.先在各组 ...
- Manacher算法学习笔记 | LeetCode#5
Manacher算法学习笔记 DECLARATION 引用来源:https://www.cnblogs.com/grandyang/p/4475985.html CONTENT 用途:寻找一个字符串的 ...
- Johnson算法学习笔记
\(Johnson\)算法学习笔记. 在最短路的学习中,我们曾学习了三种最短路的算法,\(Bellman-Ford\)算法及其队列优化\(SPFA\)算法,\(Dijkstra\)算法.这些算法可以快 ...
- 某科学的PID算法学习笔记
最近,在某社团的要求下,自学了PID算法.学完后,深切地感受到PID算法之强大.PID算法应用广泛,比如加热器.平衡车.无人机等等,是自动控制理论中比较容易理解但十分重要的算法. 下面是博主学习过程中 ...
- 【LeetCode-面试算法经典-Java实现】【096-Unique Binary Search Trees(唯一二叉搜索树)】
[096-Unique Binary Search Trees(唯一二叉搜索树)] [LeetCode-面试算法经典-Java实现][全部题目文件夹索引] 原题 Given n, how many s ...
- 二次剩余Cipolla算法学习笔记
对于同余式 \[x^2 \equiv n \pmod p\] 若对于给定的\(n, P\),存在\(x\)满足上面的式子,则乘\(n\)在模\(p\)意义下是二次剩余,否则为非二次剩余 我们需要计算的 ...
- 算法学习笔记——sort 和 qsort 提供的快速排序
这里存放的是笔者在学习算法和数据结构时相关的学习笔记,记录了笔者通过网络和书籍资料中学习到的知识点和技巧,在供自己学习和反思的同时为有需要的人提供一定的思路和帮助. 从排序开始 基本的排序算法包括冒泡 ...
- R语言实现关联规则与推荐算法(学习笔记)
R语言实现关联规则 笔者前言:以前在网上遇到很多很好的关联规则的案例,最近看到一个更好的,于是便学习一下,写个学习笔记. 1 1 0 0 2 1 1 0 0 3 1 1 0 1 4 0 0 0 0 5 ...
随机推荐
- node后台启动
node启动后会占用当前shell 后台启动方式: 1.用forever进行管理 npm install -g forever forever start index.js 2.使用nohub命令 ...
- Centos7 因内存 可用大小不足,被killed的解决办法
Linux的内存分配采取的是一种更加积极的分配策略,它假设应用申请了内存空间后并不会立即去使用它,所以允许一定量的超售,当应用真的需要使用它的时候,操作系统可能已经通过回收了其他应用的内存空间而变得有 ...
- 关于SVN浏览服务器的错误
这种错误是因为URL错误,需要把https://iZ1gyqtig7Z/svn/BoLeBang/ 换成自己的公网ip地址 https://xx.xx.xx.xxsvn/BoLeBang/ 就可以 ...
- Android通知栏介绍与适配总结(上篇)
此文已由作者黎星授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 由于历史原因,Android在发布之初对通知栏Notification的设计相当简单,而如今面对各式各样的通知 ...
- chipmunk几何算法
/* Copyright (c) 2007 Scott Lembcke * * Permission is hereby granted, free of charge, to any person ...
- Servlet实现禁用cookie重写URL获取session
前言 一个女人让他的程序员丈夫去商店买东西:你去附近的商店买些鸡蛋,如果有香蕉的话,买8个回来,这个丈夫买了8个鸡蛋回来,他的妻子大吃一惊:你为什么买了8个鸡蛋?! 程序员丈夫回答:因为他们有香蕉. ...
- [Objective-C语言教程]常量(7)
常量指的是程序在执行期间不会改变的固定值.这些固定值也称为文字.常量可以是任何基本数据类型,如整数常量,浮点常量,字符常量或字符串文字.还有枚举常量.常量被视为常规变量,只不过它们的值在定义后无法修改 ...
- 【redis基础】
基础知识 http://www.runoob.com/redis/redis-partitioning.html redis性能分析 https://www.cnblogs.com/mushroom/ ...
- css里面鼠标的形状-----》easyui哪点事
用css控制鼠标样式的语法如下:<span style="cursor:*">文本或其它页面元素</span>把 * 换成如下15个效果的一种: 下面是对这 ...
- Python+selenium 模拟wap端页面操作
from selenium.webdriver.chrome.options import OptionsmobileEmulation = {'deviceName': 'iPhone X'}opt ...