Priority Queues

May 26, 2017 | Autor: Dung Bùi | Categoria: Computer Science, Database Systems, Computer Networks, Databases
Share Embed


Descrição do Produto

Algorithms

R OBERT S EDGEWICK | K EVIN W AYNE

2.4 P RIORITY Q UEUES ‣ API and elementary implementations ‣ binary heaps

Algorithms F O U R T H

E D I T I O N

R OBERT S EDGEWICK | K EVIN W AYNE http://algs4.cs.princeton.edu

‣ heapsort ‣ event-driven simulation

2.4 P RIORITY Q UEUES ‣ API and elementary implementations ‣ binary heaps

Algorithms R OBERT S EDGEWICK | K EVIN W AYNE http://algs4.cs.princeton.edu

‣ heapsort ‣ event-driven simulation

Collections A collection is a data types that store groups of items.

data type

key operations

data structure

stack

PUSH, POP

linked list, resizing array

queue

ENQUEUE, DEQUEUE

linked list, resizing array

priority queue

INSERT,

DELETE-MAX

binary heap

symbol table

PUT, GET, DELETE

BST, hash table

set

ADD, CONTAINS, DELETE

BST, hash table

“ Show me your code and conceal your data structures, and I shall continue to be mystified. Show me your data structures, and I won't usually need your code; it'll be obvious.” — Fred Brooks 3

Priority queue Collections. Insert and delete items. Which item to delete? Stack. Remove the item most recently added. Queue. Remove the item least recently added. Randomized queue. Remove a random item. Priority queue. Remove the largest (or smallest) item. operation argument insert insert insert remove max insert insert insert remove max insert insert insert remove max

return value size

P Q E Q X A M X P L E P

1 2 3 2 3 4 5 4 5 6 7 6

contents (unordered) P P P P P P P P P P P E

Q Q E E E E E E E E M

E X X X M M M M A

A A A A A A P

M P P P L

L L E

E

P P E E E A A A A A A A 4

Priority queue API Requirement. Generic items are Comparable. Key must be Comparable (bounded type parameter)

public class MaxPQ MaxPQ() MaxPQ(Key[] a) void insert(Key v) Key delMax()

create an empty priority queue create a priority queue with given keys insert a key into the priority queue return and remove the largest key

boolean isEmpty()

is the priority queue empty?

Key max()

return the largest key

int size()

number of entries in the priority queue

5

Priority queue applications

・Event-driven simulation. ・Numerical computation. ・Data compression. ・Graph searching. ・Number theory. ・Artificial intelligence. ・Statistics. ・Operating systems. ・Computer networks. ・Discrete optimization. ・Spam filtering.

[ customers in a line, colliding particles ] [ reducing roundoff error ] [ Huffman codes ] [ Dijkstra's algorithm, Prim's algorithm ] [ sum of powers ] [ A* search ] [ online median in data stream ] [ load balancing, interrupt handling ] [ web cache ] [ bin packing, scheduling ] [ Bayesian spam filter ]

Generalizes: stack, queue, randomized queue.

6

Priority queue client example Challenge. Find the largest M items in a stream of N items.

・Fraud detection: ・NSA monitoring:

isolate $$ transactions. flag most suspicious documents.

N huge, M large

Constraint. Not enough memory to store N items. % more tinyBatch.txt Turing 6/17/1990 vonNeumann 3/26/2002 Dijkstra 8/22/2007 vonNeumann 1/11/1999 Dijkstra 11/18/1995 Hoare 5/10/1993 vonNeumann 2/12/1994 Hoare 8/18/1992 Turing 1/11/2002 Thompson 2/27/2000 Turing 2/11/1991 Hoare 8/12/2003 vonNeumann 10/13/1993 Dijkstra 9/10/2000 Turing 10/12/1993 Hoare 2/10/2005

644.08 4121.85 2678.40 4409.74 837.42 3229.27 4732.35 4381.21 66.10 4747.08 2156.86 1025.70 2520.97 708.95 3532.36 4050.20

% java TopM Thompson vonNeumann vonNeumann Hoare vonNeumann

5 < tinyBatch.txt 2/27/2000 4747.08 2/12/1994 4732.35 1/11/1999 4409.74 8/18/1992 4381.21 3/26/2002 4121.85

sort key

7

Priority queue client example Challenge. Find the largest M items in a stream of N items.

・Fraud detection: ・NSA monitoring:

isolate $$ transactions. flag most suspicious documents.

N huge, M large

Constraint. Not enough memory to store N items.

MinPQ pq = new MinPQ();

use a min-oriented pq

while (StdIn.hasNextLine()) { String line = StdIn.readLine(); Transaction item = new Transaction(line); pq.insert(item); pq contains if (pq.size() > M) largest M items pq.delMin(); }

Transaction data type is Comparable (ordered by $$)

8

Priority queue client example Challenge. Find the largest M items in a stream of N items.

implementation

time

space

sort

N log N

N

elementary PQ

MN

M

binary heap

N log M

M

best in theory

N

M

order of growth of finding the largest M in a stream of N items

9

Priority queue: unordered and ordered array implementation

operation argument insert insert insert remove max insert insert insert remove max insert insert insert remove max

return value size

P Q E Q X A M X P L E P

1 2 3 2 3 4 5 4 5 6 7 6

contents (unordered) P P P P P P P P P P P E

Q Q E E E E E E E E M

contents (ordered)

E X X X M M M M A

A A A A A A P

M P P P L

L L E

E

P P E E E A A A A A A A

Q P P P E E E E E E E

Q X P M M M L E E

X P P P M L L

X P P M M

P P P

P

A sequence of operations on a priority queue

10

Priority queue: unordered array implementation

public class UnorderedArrayMaxPQ { private Key[] pq; // pq[i] = ith element on pq private int N; // number of elements on pq public UnorderedArrayMaxPQ(int capacity) { pq = (Key[]) new Comparable[capacity];

}

no generic array creation

public boolean isEmpty() { return N == 0; } public void insert(Key x) { pq[N++] = x; } public Key delMax() { int max = 0; for (int i = 1; i < N; i++) if (less(max, i)) max = i; exch(max, N-1); should null out entry return pq[--N]; to prevent loitering }

less() and exch() similar to sorting methods (but don't pass pq[])

} 11

Priority queue elementary implementations Challenge. Implement all operations efficiently.

implementation

insert

del max

max

unordered array

1

N

N

ordered array

N

1

1

goal

log N

log N

log N

order of growth of running time for priority queue with N items

12

2.4 P RIORITY Q UEUES ‣ API and elementary implementations ‣ binary heaps

Algorithms R OBERT S EDGEWICK | K EVIN W AYNE http://algs4.cs.princeton.edu

‣ heapsort ‣ event-driven simulation

Complete binary tree Binary tree. Empty or node with links to left and right binary trees. Complete tree. Perfectly balanced, except for bottom level.

complete tree with N = 16 nodes (height = 4)

Property. Height of complete tree with N nodes is ⎣lg N⎦. Pf. Height increases only when N is a power of 2.

14

A complete binary tree in nature

15

Binary heap representations Binary heap. Array representation of a heap-ordered complete binary tree. Heap-ordered binary tree.

・Keys in nodes. ・Parent's key no smaller than children's keys.

i a[i]

0 -

1 T

2 S

3 R

S

R

4 P

5 N

6 O

7 A

P

N

O

A

8 E

9 10 11 I H G

E

I

T

Array representation.

・Indices start at 1. ・Take nodes in level order. ・No explicit links needed!

1

8 E

9 I

G

T 3 R

2 S 4 P

H

5 N 10 H

6 O

7 A

11 G

Heap representations 16

Binary heap properties Proposition. Largest key is a[1], which is root of binary tree. Proposition. Can use array indices to move through tree.

・Parent of node at k is at k/2. ・Children of node at k are at 2k and 2k+1. i a[i]

0 -

1 T

2 S

3 R

S

R

4 P

5 N

6 O

7 A

P

N

O

A

8 E

9 10 11 I H G

E

I

T

1

8 E

9 I

G

T 3 R

2 S 4 P

H

5 N 10 H

6 O

7 A

11 G

Heap representations 17

Binary heap demo Insert. Add node at end, then swim it up. Remove the maximum. Exchange root with node at end, then sink it down.

heap ordered

T

P

R

N

H

E

I

T

O

A

G

P

R

N

H

O

A

E

I

G 18

Binary heap demo Insert. Add node at end, then swim it up. Remove the maximum. Exchange root with node at end, then sink it down.

heap ordered

S

R

O

N

G

P

E

H

I

S

A

R

O

N

P

G

A

E

I

H 19

Promotion in a heap Scenario. Child's key becomes larger key than its parent's key. To eliminate the violation:

・Exchange key in child with key in parent. ・Repeat until heap order restored. S

private void swim(int k) { while (k > 1 && less(k/2, k)) { exch(k, k/2); k = k/2; } parent of node at k is at k/2 }

R

P 5

N E

I

T

H

O

A violates heap order (larger key than parent)

G 1

T 2

5 P

N E

R

S

I

H

O

A

G

Bottom-up reheapify (swim)

Peter principle. Node promoted to level of incompetence. 20

Insertion in a heap Insert. Add node at end, then swim it up. Cost. At most 1 + lg N compares. insert

remo

T R

P N

public void insert(Key x) { pq[++N] = x; swim(N); }

E

H I

G

O S

A

key to insert T R

P N E

H I

G

O

add key to heap violates heap order

S T

swim up

R

S N E

A

P I

G

O

sink down A

H

Heap operation 21

Demotion in a heap Scenario. Parent's key becomes smaller than one (or both) of its children's. To eliminate the violation:

why not smaller child?

・Exchange key in parent with key in larger child. ・Repeat until heap order restored. private void sink(int k) { children of node at k while (2*k 0) return INFINITY; double dvdv = dvx*dvx + dvy*dvy; double drdr = dx*dx + dy*dy; double sigma = this.radius + that.radius; double d = (dvdr*dvdr) - dvdv * (drdr - sigma*sigma); if (d < 0) return INFINITY; return -(dvdr + Math.sqrt(d)) / dvdv; } public void bounceOff(Particle that) { double dx = that.rx - this.rx, dy = that.ry double dvx = that.vx - this.vx, dvy = that.vy double dvdr = dx*dvx + dy*dvy; double dist = this.radius + that.radius; double J = 2 * this.mass * that.mass * dvdr / double Jx = J * dx / dist; double Jy = J * dy / dist; this.vx += Jx / this.mass; this.vy += Jy / this.mass; that.vx -= Jx / that.mass; that.vy -= Jy / that.mass; this.count++; Important note: This is physics, that.count++; }

no collision

- this.ry; - this.vy;

((this.mass + that.mass) * dist);

so we won’t be testing you on it! 61

Collision system: event-driven simulation main loop two particles on a collision course

Initialization.

・Fill PQ with all potential particle-wall collisions. ・Fill PQ with all potential particle-particle collisions. third particle interferes: no collision

“potential” since collision may not happen if some other collision intervenes

An invalidated event

Main loop.

・Delete the impending event from PQ (min priority = t). ・If the event has been invalidated, ignore it. ・Advance all particles to time t, on a straight-line trajectory. ・Update the velocities of the colliding particle(s). ・Predict future particle-wall and particle-particle collisions involving the colliding particle(s) and insert events onto PQ.

62

Event data type Conventions.

・Neither particle null ・One particle null ・Both particles null

⇒ particle-particle collision. ⇒ particle-wall collision. ⇒ redraw event.

private class Event implements Comparable { private double time; // time of event private Particle a, b; // particles involved in event private int countA, countB; // collision counts for a and b public Event(double t, Particle a, Particle b) { }

create event

public int compareTo(Event that) { return this.time - that.time;

ordered by time

public boolean isValid() { }

} invalid if intervening collision

}

63

Collision system implementation: skeleton public class CollisionSystem { private MinPQ pq; private double t = 0.0; private Particle[] particles;

// the priority queue // simulation clock time // the array of particles

public CollisionSystem(Particle[] particles) { } private void predict(Particle a) add to PQ all particle-wall and particleparticle collisions involving this particle { if (a == null) return; for (int i = 0; i < N; i++) { double dt = a.timeToHit(particles[i]); pq.insert(new Event(t + dt, a, particles[i])); } pq.insert(new Event(t + a.timeToHitVerticalWall() , a, null)); pq.insert(new Event(t + a.timeToHitHorizontalWall(), null, a)); } private void redraw()

{ }

public void simulate() {

/* see next slide */

}

} 64

Collision system implementation: main event-driven simulation loop

public void simulate() { pq = new MinPQ(); for(int i = 0; i < N; i++) predict(particles[i]); pq.insert(new Event(0, null, null)); while(!pq.isEmpty()) { Event event = pq.delMin(); if(!event.isValid()) continue; Particle a = event.a; Particle b = event.b;

get next event

for(int i = 0; i < N; i++) particles[i].move(event.time - t); t = event.time; if (a != else if (a != else if (a == else if (a == predict(a); predict(b);

null null null null

&& && && &&

b b b b

!= == != ==

null) null) null) null)

initialize PQ with collision events and redraw event

a.bounceOff(b); a.bounceOffVerticalWall() b.bounceOffHorizontalWall(); redraw();

update positions and time

process event

predict new events based on changes

} }

65

Particle collision simulation example 1

% java CollisionSystem 100

66

Particle collision simulation example 2

% java CollisionSystem < billiards.txt

67

Particle collision simulation example 3

% java CollisionSystem < brownian.txt

68

Particle collision simulation example 4

% java CollisionSystem < diffusion.txt

69

Lihat lebih banyak...

Comentários

Copyright © 2017 DADOSPDF Inc.