chapter 5 trees -...

93
CHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj Sahni, and Susan Anderson-Freed “Fundamentals of Data Structures in C”,

Upload: others

Post on 20-Jan-2021

20 views

Category:

Documents


1 download

TRANSCRIPT

Page 1: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5

Trees

All the programs in this file are selected fromEllis Horowitz, Sartaj Sahni, and Susan Anderson-Freed“Fundamentals of Data Structures in C”,

Page 2: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 2

Trees

Gill Tansey

Brunhilde

Tweed Zoe

Terry

Honey Bear

Crocus Primrose

Coyote

Nous Belle

Nugget

Brandy

Dusty

Root

leaf

Page 3: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 3

Definition of Tree

A tree is a finite set of one or more nodes such that:– There is a specially designated node called

the root.– The remaining nodes are partitioned into n>=0 disjoint

sets T1, ..., Tn, where each of these sets is a tree.– We call T1, ..., Tn the subtrees of the root.

Page 4: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 4

Level and Depth

Level

1

2

3

4

1. node (13)2. leaf (terminal)3. nonterminal4. parent5. children6. sibling7. degree of a tree (3)8. ancestor9. level of a node10. height of a tree (4) K L

E F

B

G

C

M

H I J

D

A3

2 1 3

2 0 0 1 0 0

0 0 0

1

2 2 2

3 3 3 3 3 3

4 4 4

簡報者
簡報註解
Ancestor:祖宗,祖先
Page 5: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

5

Terminology The degree of a node is the number of subtrees

of the node– The degree of A is 3; the degree of C is 1.

The node with degree 0 is a leaf or terminal node.

A node that has subtrees is the parent of the subtrees.

These subtrees are the children of the node.

Children of the same parent are siblings. The ancestors of a node are all the nodes

along the path from the root to the node.

簡報者
簡報註解
Terminology : (總稱)術語,專門用語 Sibling :兄弟姊妹 Ancestors :祖宗,祖先
Page 6: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 6

Representation of Trees

List Representation– ( A ( B ( E ( K, L ), F ), C ( G ), D ( H ( M ), I, J ) ) )– The root comes first, followed by a list of sub-trees

data link 1 link 2 ... link n

How many link fields areneeded in such a representation?

Page 7: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 7

Left Child - Right Sibling

A

B C D

E F G H I J

K L M

dataleft child right sibling

Page 8: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 8

Binary Trees

A binary tree is a finite set of nodes that is either empty or consists of a root and two disjoint binary trees called the left subtreeand the right subtree.

Any tree can be transformed into binary tree.– by left child-right sibling representation

The left subtree and the right subtree are distinguished.

簡報者
簡報註解
Distinguished:  區別
Page 9: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

J

IM

HL

A

B

C

D

E

F GK

*Figure 5.2 Left child-right child tree representation of a tree

Page 10: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 10

Abstract Data Type Binary_Tree structure Binary_Tree(abbreviated BinTree) is objects: a finite set of nodes either empty or

consisting of a root node, left Binary_Tree, and right Binary_Tree.

functions:for all bt, bt1, bt2 ∈ BinTree, item ∈ element

Bintree Create()::= creates an empty binary tree Boolean IsEmpty(bt)::= if (bt==empty binary

tree) return TRUE else return FALSE

Page 11: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 11

BinTree MakeBT(bt1, item, bt2)::= return a binary tree whose left subtree is bt1, whose right subtree is bt2, and whose root node contains the data item

Bintree Lchild(bt)::= if (IsEmpty(bt)) return error else return the left subtree of bt

element Data(bt)::= if (IsEmpty(bt)) return errorelse return the data in the root node of bt

Bintree Rchild(bt)::= if (IsEmpty(bt)) return error else return the right subtree of bt

Abstract Data Type Binary_Tree

Page 12: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 12

Samples of Trees

A

B

A

B

A

B C

GE

I

D

H

F

Complete Binary Tree

Skewed Binary Tree

E

C

D

1

2

3

45

簡報者
簡報註解
Skewed :歪曲的,曲解的
Page 13: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 13

Maximum Number of Nodes in BT

The maximum number of nodes on level i of a binary tree is 2i-1, i>=1.

The maximum nubmer of nodes in a binary tree of depth k is 2k-1, k>=1.

Prove by induction.

2 2 11

1

i

i

kk−

=∑ = −

pp. 200

簡報者
簡報註解
pp. 200
Page 14: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

14

Relations between Number ofLeaf Nodes and Nodes of Degree 2

For any nonempty binary tree, T, if n0 is the number of leaf nodes and n2 the number of nodes of degree 2, then n0=n2+1

proof: Let n and B denote the total number of nodes &

branches in T. Let n0, n1, n2 represent the nodes with no children,

single child, and two children respectively.n= n0+n1+n2, n=B+1, n=B+1=n1+2n2+1,n1+2n2+1= n0+n1+n2 ==> n0=n2+1

n0=n2+1

簡報者
簡報註解
pp. 201
Page 15: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 515

Full BT VS Complete BT A full binary tree of depth k is a binary tree of

depth k having 2 -1 nodes, k>=0. A binary tree with n nodes and depth k is

complete iff its nodes correspond to the nodes numbered from 1 to n in the full binary tree of depth k.

k

A

B C

GE

I

D

H

F

A

B C

GE

K

D

J

F

IH ONML

由上至下,由左至右編號

Full binary tree of depth 4Complete binary tree

Page 16: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 16

Binary Tree Representations

If a complete binary tree with n nodes (depth =log n + 1) is represented sequentially, then forany node with index i, 1<=i<=n, we have:– parent(i) is at i/2 if i!=1. If i=1, i is at the root and

has no parent.– left_child(i) ia at 2i if 2i<=n. If 2i>n, then i has no

left child.– right_child(i) ia at 2i+1 if 2i +1 <=n. If 2i +1 >n,

then i has no right child.

Page 17: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

17

Sequential Representation

AB--C------D--.E

[1][2][3][4][5][6][7][8][9].[16]

[1][2][3][4][5][6][7][8][9]

ABCDEFGHI

A

B

E

C

D

A

B C

GE

I

D

H

F

(1) waste space(2) insertion/deletion problem

Page 18: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 18

Linked Representation

typedef struct node *tree_pointer;

typedef struct node {

int data;

tree_pointer left_child, right_child;

};

dataleft_child right_child

data

left_child right_child

Page 19: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 19

Binary Tree Traversals

Let L, V, and R stand for moving left, visiting the node, and moving right.

There are six possible combinations of traversal– LVR, LRV, VLR, VRL, RVL, RLV

Adopt convention that we traverse left before right, only 3 traversals remain– LVR, LRV, VLR– inorder, postorder, preorder

簡報者
簡報註解
Convention:  公約,協定
Page 20: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 20

Arithmetic Expression Using BT

+

*

A

*

/

E

D

C

B

inorder traversalA / B * C * D + Einfix expression

preorder traversal+ * * / A B C D Eprefix expression

postorder traversalA B / C * D * E +postfix expression

level order traversal+ * E * D / C A B

Page 21: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 21

Inorder Traversal (recursive version)

void inorder(tree_pointer ptr)

/* inorder tree traversal */

{

if (ptr) {

inorder(ptr->left_child);

printf(“%d”, ptr->data);

inorder(ptr->right_child);

}

}

A / B * C * D + E

簡報者
簡報註解
Inorder LVR
Page 22: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 22

Preorder Traversal (recursive version)

void preorder(tree_pointer ptr)

/* preorder tree traversal */

{

if (ptr) {

printf(“%d”, ptr->data);

preorder(ptr->left_child);

preorder(ptr->right_child);

}

}

+ * * / A B C D E

簡報者
簡報註解
VLR
Page 23: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 23

Postorder Traversal (recursive version)

void postorder(tree_pointer ptr)

/* postorder tree traversal */

{

if (ptr) {

postorder(ptr->left_child);

postorder(ptr->right_child);

printf(“%d”, ptr->data);

}

}

A B / C * D * E +

簡報者
簡報註解
LRV
Page 24: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 24

Iterative Inorder Traversal(using stack)

void iterInorder(tree_pointer node){

int top= -1; /* initialize stack */tree_pointer stack[MAX_STACK_SIZE];for (;;) {for (; node; node=node->left_child)push(&top, node);/* add to stack */

node= pop(&top); /* delete from stack */

if (!node) break; /* empty stack */printf(“%D”, node->data);node = node->right_child;

}} O(n)

簡報者
簡報註解
LVR
Page 25: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 25

Trace Operations of Inorder TraversalCall of inorder Value in root Action Call of inorder Value in root Action1 + 11 C2 * 12 NULL3 * 11 C printf4 / 13 NULL5 A 2 * printf6 NULL 14 D5 A printf 15 NULL7 NULL 14 D printf4 / printf 16 NULL8 B 1 + printf9 NULL 17 E8 B printf 18 NULL10 NULL 17 E printf3 * printf 19 NULL

LVR

Page 26: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 26

Level Order Traversal(using queue)

void levelOrder(tree_pointer ptr)/* level order tree traversal */{

int front = rear = 0;tree_pointer queue[MAX_QUEUE_SIZE];if (!ptr) return; /* empty queue */addq(ptr);for (;;) {ptr = delete();

Page 27: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 27

if (ptr) {printf(“%d”, ptr->data);if (ptr->left_child)addq(ptr->left_child);

if (ptr->right_child)addq(ptr->right_child);

}else break;

}}

+ * E * D / C A B

Page 28: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 28

Copying Binary Treestree_pointer copy(tree_pointer original){tree_pointer temp;if (original) {

temp=(tree_pointer) malloc(sizeof(node));if (IS_FULL(temp)) {

fprintf(stderr, “the memory is full\n”);exit(1);

}temp->left_child=copy(original->left_child);temp->right_child=copy(original->right_child);temp->data=original->data;return temp;

}return NULL;} postorder

Page 29: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 29

Equality of Binary Trees

int equal(tree_pointer first, tree_pointer second)

{

/* function returns FALSE if the binary trees firstand second are not equal, otherwise it returns TRUE */

return ((!first && !second) || (first && second &&

(first->data == second->data) &&

equal(first->left_child, second->left_child) &&

equal(first->right_child, second->right_child)))

}

the same topology and data

Page 30: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 30

Propositional Calculus Expression

A variable is an expression. If x and y are expressions, then ¬x, x∧y,

x∨y are expressions. Parentheses can be used to alter the normal

order of evaluation (¬ > ∧ > ∨). Example: x1 ∨ (x2 ∧ ¬x3) satisfiability problem: Is there an

assignment to make an expression true?

簡報者
簡報註解
Propositional:建議的;提議的 Parentheses:括弧 Alter:改變
Page 31: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

¬∨

X3¬¬X1

X2 X1

∧ X3

(x1 ∧ ¬x2) ∨ (¬ x1 ∧ x3) ∨ ¬x3

(t,t,t)(t,t,f)(t,f,t)(t,f,f)(f,t,t)(f,t,f)(f,f,t)(f,f,f)

2n possible combinationsfor n variables

postorder traversal (postfix evaluation)LRV

Page 32: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

left_child data value right_child

typedef emun {not, and, or, true, false } logical;typedef struct node *tree_pointer;typedef struct node {

tree_pointer left_child;logical data;short int value;tree_pointer right_child;} ;

Node Structure

Page 33: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

for (all 2n possible combinations) {generate the next combination;replace the variables by their values;evaluate root by traversing it in postorder;if (root->value) {

printf(<combination>);return;

}}printf(“No satisfiable combination \n”);

First version of satisfiability algorithm

簡報者
簡報註解
???
Page 34: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

void postOrderEval(tree_pointer node){/* modified post order traversal to evaluate a propositional calculus tree */

if (node) {post_order_eval(node->left_child);post_order_eval(node->right_child);switch(node->data) {

case not: node->value =!node->right_child->value;break;

Post-order-eval function

Page 35: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

case and: node->value =node->right_child->value &&node->left_child->value;break;

case or: node->value =node->right_child->value | |node->left_child->value;break;

case true: node->value = TRUE;break;

case false: node->value = FALSE;}

}}

Page 36: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 36

Threaded Binary Trees Many null pointers in current representation

of binary treesn: number of nodes; total links: 2nnumber of non-null links: n-1

Replace these null pointers with some useful “threads”.

null links: 2n-(n-1)=> n+1

Page 37: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 37

Threaded Binary Trees (Continued)

If ptr->left_child is null, replace it with a pointer to the node that would be visited before ptr in an inorder traversal

If ptr->right_child is null, replace it with a pointer to the node that would be visited after ptr in an inorder traversal

簡報者
簡報註解
左右引樹分別使用在中至排序法上, 指向此節點的上一個節點及下一個節點
Page 38: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 38

A Threaded Binary Tree

A

B C

GE

I

D

H

F

root

dangling

dangling

inorder traversal:H, D, I, B, E, A, F, C, G

簡報者
簡報註解
Dangling:懸擺,懸蕩;吊,掛
Page 39: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

TRUE FALSE

Data Structures for Threaded BT

typedef struct threaded_tree *threaded_pointer;

typedef struct threaded_tree {

short int left_thread;

threaded_pointer left_child;

char data;

threaded_pointer right_child;

short int right_thread; };

left_thread left_child data right_child right_thread

FALSE: childTRUE: thread

Page 40: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 40

Memory Representation of A Threaded BT

f f--

f fA

f fCf fB

t tE t tF t Gf fD

t tIt tH

root

Page 41: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 41

Next Node in Threaded BT

threaded_pointer insucc(threaded_pointer tree)

{

threaded_pointer temp;

temp = tree->right_child;

if (!tree->right_thread)

while (!temp->left_thread)

temp = temp->left_child;

return temp;

}

簡報者
簡報註解
/* 在引線二元樹中找樹 “右子機” 的中序後一個節點*/ 找出某節點的中序後一個節點
Page 42: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 42

Inorder Traversal of Threaded BT

void tinorder(threaded_pointer tree){/* traverse the threaded binary tree inorder */

threaded_pointer temp = tree;for (;;) {

temp = insucc(temp);if (temp==tree) break;printf(“%3c”, temp->data);

}}

O(n)

簡報者
簡報註解
引線二元樹的中序走訪法
Page 43: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 43

Inserting Nodes into Threaded BTs Insert child as the right child of node (parent)

– change parent->right_thread to FALSE– set child->left_thread and child->right_thread

to TRUE1. set child->right_child to parent->right_child2. set child->left_child to point to parent3. change parent->right_child to point to child

Page 44: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 44

Examples

root

parent

A

B

C Dchild

root

parent

A

B

C D child

emptyInsert a node D as a right child of B.

(1)

(2)

(3)

(a)

Page 45: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

*Figure 5.24: Insertion of child as a right child of parent in a threaded binary tree

nonempty

(1)

(3)

(4)

(2)

Page 46: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 46

Right Insertion in Threaded BTs

void insertRight(threaded_pointer parent, threaded_pointer child)

{threaded_pointer temp;child->right_child = parent->right_child;child->right_thread = parent->right_thread;child->left_child = parent; child->left_thread = TRUE;parent->right_child = child;parent->right_thread = FALSE;if (!child->right_thread) { temp = insucc(child);temp->left_child = child;

}}

(1)

(2)

(3)

(4)

case (a)

case (b)

簡報者
簡報註解
插入引線樹的右子樹
Page 47: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 47

Heap A max tree is a tree in which the key value in

each node is no smaller than the key values in its children. – A max heap is a complete binary tree that is also a max tree.

A min tree is a tree in which the key value in each node is no larger than the key values in its children. – A min heap is a complete binary tree that is also a min tree.

Operations on heaps– creation of an empty heap– insertion of a new element into the heap – deletion of the largest element from the heap

Page 48: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

*Figure 5.25: Max heaps

[4]

14

12 7

810 6

9

6 3

5

30

25

[1]

[2] [3]

[5] [6]

[1]

[2] [3]

[4]

[1]

[2]

Property:The root of max heap (min heap) contains the largest (smallest).

Page 49: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

2

7 4

810 6

10

20 83

50

11

21

[1]

[2] [3]

[5] [6]

[1]

[2] [3]

[4]

[1]

[2]

[4]

*Figure 5.26: Min heaps

Page 50: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

50

ADT for Max Heapstructure MaxHeap objects: a complete binary tree of n > 0 elements organized so that

the value in each node is at least as large as those in its childrenfunctions:for all heap belong to MaxHeap, item belong to Element, n, max_size belong to integer

MaxHeap Create(max_size)::= create an empty heap that can hold a maximum of max_size elements

Boolean HeapFull(heap, n)::= if (n==max_size) return TRUEelse return FALSE

MaxHeap Insert(heap, item, n)::= if (!HeapFull(heap,n)) insert item into heap and return the resulting heap

else return error Boolean HeapEmpty(heap, n)::= if (n>0) return FALSE

else return TRUE Element Delete(heap,n)::= if (!HeapEmpty(heap,n)) return one

instance of the largest element in the heap and remove it from the heap

else return error

Page 51: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 51

Application: priority queue

Machine service (Example 5.1)– amount of time (min heap)– amount of payment (max heap)

Factory (Example 5.2)– time tag

Page 52: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 52

ADT MaxPriorityQuere是物件:n個元素形成的集合(n>0),每個元素有一個鍵值函式:對所有的q∈MaxPriorityQueue,item∈Element,n是整

數MaxPriorityQueuecreate(max_size)

::= 建立一個空的優先權佇列

Boolean isEmpty(q,n) ::= if(n>0) return FALSEelse return TRUE

Element top(q,n) ::= if(!isEmpty(q,n)) return q內最大的元素else return 錯誤

Element pop(q,n) ::= if(!isEmpty(q,n)) return q內最大的元素並把它從堆積中移除else return 錯誤

MaxPriorityQueue push(q,item,n)

::= 把item插入q中並回傳優先權佇列的結果

Page 53: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 53

Data Structures

unordered linked list unordered array sorted linked list sorted array heap

Page 54: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

Representation Insertion Deletion

Unorderedarray

Θ(1) Θ(n)

Unorderedlinked list

Θ(1) Θ(n)

Sorted array O(n) Θ(1)Sorted linkedlist

O(n) Θ(1)

Max heap O(log2n) O(log2n)

*Figure 5.27: Priority queue representations

Page 55: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 55

Example of Insertion to Max Heap

20

15 2

14 10

initial location of new node

21

15 20

14 10 2

insert 21 into heap

20

15 5

14 10 2

insert 5 into heap

Page 56: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 56

Insertion into a Max Heapvoid push(element item, int *n){/* 把項目加入目前大小是n的最大堆積 */

int i;if (HEAP_FULL(*n)) {

fprintf(stderr, “the heap is full.\n”);exit(1);

}i = ++(*n);while ((i!=1)&&(item.key>heap[i/2].key)) {

heap[i] = heap[i/2]; // moving up to rooti /= 2;

}heap[i]= item;

}

2k-1=n ==> k=log2(n+1)

O(log2n)

簡報者
簡報註解
加入元素到最大堆積裡 pp.227
Page 57: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 57

Example of Deletion from Max Heap

20remove

15 2

14 10

10

15 2

14

15

14 2

10

Page 58: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 58

Deletion from a Max Heapelement pop(int *n){/* 從堆積中刪除鍵最高的元素 */int parent, child;element item, temp;if (HEAP_EMPTY(*n)) {

fprintf(stderr, “The heap is empty\n”);exit(1);

}/* save value of the element with the highest key */

item = heap[1];/* use last element in heap to adjust heap */temp = heap[(*n)--];parent = 1;child = 2;

Page 59: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 59

while (child <= *n) {/* find the larger child of the current

parent */if ((child < *n)&&

(heap[child].key<heap[child+1].key))child++;

if (temp.key >= heap[child].key) break;/* move to the next lower level */heap[parent] = heap[child];child *= 2;

}heap[parent] = temp;return item;

}

Page 60: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 60

ADT Dictionary是物件:n個資料對形成的集合(n>0),每個資料對有一個鍵值和搭配

的項目函式:對於所有的d∈Dictionary,item∈Item,k∈Key,n是整數

Dictionary Create(max_size) ::= 建立一個空的字典

Boolean IsEmpty(d,n) ::= if(n>0) return FALSEelse return TRUE

Element Search(d,k) ::= return 鍵值為k的項目return NULL 如果沒有此元素

Element Delete(d,k) ::= 刪除並回傳(如果有)鍵值為k的項目

void Insert(d,item,k) ::= 把鍵值為k的item插入d中

Page 61: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 61

Binary Search Tree Heap

– a min (max) element is deleted. O(log2n)– deletion of an arbitrary element O(n)– search for an arbitrary element O(n)

Binary search tree– Every element has a unique key.– The keys in a nonempty left subtree (right

subtree) are smaller (larger) than the key in the root of subtree.

– The left and right subtrees are also binary search trees.

Page 62: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 62

Examples of Binary Search Trees

20

12 25

10 15

30

5 40

2

60

70

65 8022

Page 63: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 63

Searching a Binary Search Treetree_pointer search(tree_pointer root,

int key){/* return a pointer to the node that contains key. If there is no such node, return NULL */

if (!root) return NULL;if (key == root->data) return root;if (key < root->data)

return search(root->left_child,key);

return search(root->right_child,key);}

Page 64: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 64

Another Searching Algorithmtree_pointer iterSearch(tree_pointer tree, int key)

{

while (tree) {

if (key == tree->data) return tree;

if (key < tree->data)

tree = tree->left_child;

else tree = tree->right_child;

}

return NULL;

}

O(h)

Page 65: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 65

Insert Node in Binary Search Tree

30

5 40

2

30

5 40

2 35 80

30

5 40

2 80

Insert 80 Insert 35

Page 66: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 66

Insertion into a Binary Search Treevoid insert(tree_pointer *node, int k, iType theItem)

{tree_pointer ptr, temp = modified_search(*node, k);

if (temp || !(*node)) {/* k不在樹中 */ptr = (tree_pointer) malloc(sizeof(node));if (IS_FULL(ptr)) {

fprintf(stderr, “The memory is full\n”);exit(1);

}ptr->data.key = k; ptr->data.item = theItem;ptr->left_child = ptr->right_child = NULL;if (*node)

if (k < temp->data) temp->left_child=ptr;else temp->right_child = ptr;

else *node = ptr;}

}

簡報者
簡報註解
把字典對插入二元搜尋樹中
Page 67: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

Deletion for a Binary Search Tree

CHAPTER 5 68

40

5

(a) (b)

802

2 40

5

80

5

Page 68: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 569

Deletion for a Binary Search Tree40

20 60

10 30 50 70

45 55

52

40

20 55

10 30 50 70

45 52

Before deleting 60 After deleting 60

non-leafnode

In the left, to find the maximumIn the right, to find the minmum

Page 69: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

Split a Binary Search Treevoid split (nodePointer *theTree, int k, nodePointer *samll, element *mid, nodePointer *big){ /* 根據鍵k來分割二元搜尋樹 */

if (!theTree) {*small = *big = 0; (*mid).key = -1; return;} /* 空樹 */nodePointer sHead, bHead, s, b, currentNode;

/* 替small和big建立標頭節點 */MALLOC(sHead, sizeof(*sHead));MALLOC(bHead, sizeof(*bHead));s = sHead, b = bHead;/* 執行分割 */currentNode = *theTree;while (currentNode)

CHAPTER 5 70

Page 70: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 71

if (k < currentNode→data.key) { /* 加到big */b→leftChild = currentNode; b = currentNode; currentNode = currentNode→leftChild; }else if (k > currentNode→data.key) { /* 加到 small */s→rightChild = currentNode; s = currentNode; currentNode = currentNode→rightChild; }

else { /* 在currentNode做分割 */s→rightChild = currentNode→leftChild;b→leftChild = currentNode→rightChild;*small = sHead→rightChild; free(sHead);*big = bHead→leftChild; free(bHead);(*mid).item = currentNode→data.item;(*mid).key = currentNode→data.key;free(currentNode);return; }

Page 71: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 72

/* 沒有鍵為k的字典對 */s→rightChild = b→leftChild = 0;*small = sHead→rightChild; free(sHead);*big = bHead→leftChild; free(bHead);(*mid).key = -1;

return;}

Page 72: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 73

Selection Trees(1) Winner tree(2) Loser tree

Page 73: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 74

Winner tree6

6

9 6 8 17

8 9 90 1720 610 91516

2038

2030

1525

1550

1116

100110

1820

run 1 run 2 run 3 run 4 run 5 run 6 run 7 run 8orde

red

sequ

ence

Sequential allocationscheme(complete binary tree) 1

28

Each node representsthe smaller of its twochildren.

3

4 5 6 7

8 9 10 11 12 13 14 15

Page 74: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

*Figure 5.35: Selection tree of Figure 5.34 after one record has beenoutput and the tree restructured (nodes that were changed are ticked)

15

16

20

3015

50

25

25

20

3811

16

100

110

18

20

108

99

2010

1511

812

913

9014

1715

94

155

86 17

7

92

83

81

Page 75: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 76

Analysis

K: # of runs n: # of records setup time: O(K) restructure time: O(log2K) merge time: O(nlog2K) slight modification: loser tree

– consider the parent node only (vs. sibling nodes)

(K-1)

log2(K+1)

Page 76: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

108

99

2010

611

812

913

9014

1715

104

205

96

907

92

173

81

6

Run 1 2 3 4 5 6 7 8

overallwinner

*Figure 5.34: Tree of losers corresponding to Figure 5.32

15

159

8

15

15

9

Page 77: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 78

Forest

Definition: A forest is a set of n >= 0 disjoint trees

A E G

B C D F H I G

H

I

A

B

C

D

F

E

Forest

Page 78: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 79

Transform a forest into a binary tree

T1, T2, …, Tn: a forest of treesB(T1, T2, …, Tn): a binary tree corresponding to this forest

Algorithm(1) empty, if n = 0(2) has root equal to root(T1)

has left subtree equal to B(T11,T12,…,T1m)has right subtree equal to B(T2,T3,…,Tn)

Page 79: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 80

Forest Traversals

Preorder (V)– If F is empty, then return– Visit the root of the first tree of F– Taverse the subtrees of the first tree in tree preorder– Traverse the remaining trees of F in preorder

Inorder (LVR)– If F is empty, then return– Traverse the subtrees of the first tree in tree inorder– Visit the root of the first tree– Traverse the remaining trees of F is indorer

簡報者
簡報註解
Preorder : VLR Inorder : LVR
Page 80: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 81

D

H

A

B

F G

CE

I

J

inorder: EFBGCHIJDApreorder: ABEFCGDHIJ

A

B C D

E FG H I J

BEF

CG

DHIJ

preorder

Page 81: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 82

Set Representation

S1={0, 6, 7, 8}, S2={1, 4, 9}, S3={2, 3, 5}

Two operations considered here– Disjoint set union S1 ∪ S2={0,6,7,8,1,4,9}– Find(i): Find the set containing the element i.

3 ∈ S3, 8 ∈ S1

0

6 7 8

1

4 9

2

3 5

Si ∩ Sj = φ

簡報者
簡報註解
交集 : Intersection
Page 82: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 83

Disjoint Set Union

1

4 9

0

6 7 8

1

4 90

6 7 8

Possible representation for S1 union S2

Make one of the trees a subtree of the other

S1 ∪ S2

Page 83: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

0

6 7 8

4

1 9

2

3 5

Set Name

Pointer

S1

S2

S3

*Figure 5.39:Data Representation of S1S2and S3

Page 84: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 85

Array Representation for Set

int simpleFind(int i){

for (; parent[i]>=0; i=parent[i]);return i;

}

void simpleUnion(int i, int j){

parent[i]= j;}

i [0] [1] [2] [3] [4] [5] [6] [7] [8] [9]

parent -1 4 -1 2 -1 2 0 0 0 4

Page 85: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

n-1

n-2

0

*Figure 5.41:Degenerate tree (退化樹)

union operationO(n) n-1

find operationO(n2) i

i

n

=∑

2

union(0,1), find(0)union(1,2), find(0)...union(n-2,n-1),find(0)

degenerate tree

簡報者
簡報註解
Degenerate: 衰退的;墮落的
Page 86: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

*Figure 5.42:Trees obtained using the weighting rule

weighting rule for union(i,j): if # of nodes in i < # in j then make j the parent of i

0 1 • • • n-1 0 2 • • • n-1

1

0 3 • • • n-1

21起始狀況

Union (0,1) Union (0,2)

0 4 • • • n-1

31

Union (0,3)

2• • •

0

1 2 3 n-1

Union (0,n-1)

• • •

Page 87: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

Modified Union Operationvoid weightedUnion(int i, int j){

//parent[i]=-count[i] and parent=-count[j]int temp = parent[i]+ parent[j];if (parent[i]>parent[j]) {

parent[i]=j; /* make j the new root*/

parent[j]=temp;}else {

parent[j]=i; /* make i the new root*/

parent[i]=temp;}

}

If the number of nodes in tree i is less than the number in tree j, thenmake j the parent of i; otherwisemake i the parent of j.

Keep a count in the root of tree

簡報者
簡報註解
使用加權規則的聯集函式
Page 88: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

Figure 5.43:Trees ach

0[-1]

1[-1]

2[-1]

3[-1]

4[-1]

5[-1]

6[-1]

7[-1]

(a) 一開始樹的高度都是1

0

1

[-2]2

3

[-2]4

5

[-2]6

7

[-2]

(b) 執行Union (0,1),(2,3),(4,5),與 (6,7) 後樹之高度為 2

0[-4]

1 2

3

4[-4]

5 6

7

(c) 執行Union (0,2) 與 (4,6) 後樹之高度為 3

0[-8]

2

3

1 4

5 6

7

(d) 執行Union (0,4) 後樹之高度為 4

簡報者
簡報註解
跟圖5.42相比較, 它使用二二合併, 而不是一個一個node加在tree
Page 89: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 90

collapsingFind(i) Operationint collapsingFind(int i){

int root, trail, lead;for (root=i; parent[root]>=0;

root=parent[root]);for (trail=i; trail!=root;

trail=lead) {lead = parent[trail];parent[trail]= root;

}return root:

}

If j is a node on the path fromi to its root then make j a child of the root

簡報者
簡報註解
瓦解規則
Page 90: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 91

0

1 2 4

3 5 6

7

0

1 2 4

3 5

6 7

find(7) find(7) find(7) find(7) find(7) find(7) find(7) find(7)go up 3 1 1 1 1 1 1 1reset 2

13 moves (vs. 24 moves)

Page 91: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 92

Application to Equivalence Classes

Find equivalence class i ≡ j Find Si and Sj such that i ∈ Si and j ∈ Sj

(two finds)– Si = Sj do nothing– Si ≠ Sj union(Si , Sj)

example0 ≡ 4, 3 ≡ 1, 6 ≡ 10, 8 ≡ 9, 7 ≡ 4, 6 ≡ 8,3 ≡ 5, 2 ≡ 11, 11 ≡ 0{0, 2, 4, 7, 11}, {1, 3, 5}, {6, 8, 9, 10}

Page 92: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

1 2 3 4 5 8 96 7 10 11

0 3 6 8 2 5 7 11

0

4 1 10 9

[-2] [-2] [-2] [-2] [-1] [-1] [-1] [-1]

[-1][-1][-1][-1][-1][-1][-1][-1][-1][-1][-1][-1]

(a) 起始樹

(b) 處理完 0 ≡ 4, 3 ≡ 1, 6 ≡ 10, 8 ≡ 9 後高度為 2 的樹

1

23

4 58

9

6

7 10 11

0

12

3

4 58

9

6

7 10

11

0

[-3] [-4] [-3] [-2]

[-5] [-4] [-3]

(d) 處理完 11 ≡ 0 後的樹

(c) 處理完 7 ≡ 4, 6 ≡ 8, 3 ≡ 5, 2 ≡ 11 後的樹

Page 93: CHAPTER 5 Trees - 國立中興大學wccclab.cs.nchu.edu.tw/.../106-1_Data_Structure/chapter5.pdfCHAPTER 5 Trees All the programs in this file are selected from Ellis Horowitz, Sartaj

CHAPTER 5 94

preorder: A B C D E F G H Iinorder: B C A E D G H F I

A

B, C D, E, F, G, H, I

A

D, E, F, G, H, IB

C

A

B

C

D

E F

G I

H