Bài giảng Phân tích thiết kế giải thuật: Chương 5 - ĐH Bách khoa
lượt xem 6
download
Dưới đây là bài giảng Phân tích thiết kế giải thuật: Chương 5 - Heap nhị thức. Mời các bạn tham khảo bài giảng để bổ sung thêm kiến thức về các heap hợp nhất được; thời gian chạy của các thao tác lên heaps hợp nhất được; định nghĩa cây nhị thức; đặc tính của cây nhị thức; tính chất của heap nhị thức và một sô kiến thức khác.
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Bài giảng Phân tích thiết kế giải thuật: Chương 5 - ĐH Bách khoa
- Các heap hợp nhất được ° Một heap hợp nhất được (mergeable heap) là một cấu trúc dữ liệu hỗ trợ năm thao tác sau (gọi là các thao tác heap hợp nhất được). – MAKEHEAP() tạo và trả về một heap trống. – INSERT(H, x) chèn nút x, mà trường key của nó đã được điền, vào heap H . – MINIMUM(H) trả về một con trỏ chỉ đến nút trong heap H mà khóa của nó là nhỏ nhất. – EXTRACTMIN(H) tách ra nút có khóa nhỏ nhất khỏi H, và trả về một con trỏ chỉ đến nút đó. – UNION(H1, H2) tạo và trả về một heap mới chứa tất cả các nút của các heaps H1 và H2 . Các heaps H1 và H2 sẽ bị hủy bởi thao tác này. 7.3.2004 Chương 5: Heap nhị thức 1
- Thời gian chạy của các thao tác lên heaps hợp nhất được ° n là số nút của heap Thủ tục heap heap heap nhị phân nhị thức Fibonacci (worstcase) (worstcase) (khấu hao) MAKEHEAP (1) (1) (1) INSERT (lg n) O(lg n) (1) MINIMUM (1) O(lg n) (1) EXTRACTMIN (lg n) (lg n) O(lg n) UNION (n) O(lg n) (1) DECREASEKEY (lg n) (lg n) (1) DELETE (lg n) (lg n) O(lg n) 7.3.2004 Chương 5: Heap nhị thức 2
- Heap nhị thức ° Các thao tác khác – DECREASEKEY(H, x, k) gán vào nút x trong heap H trị mới k của khóa, k nhỏ hơn hay bằng trị hiện thời của khóa. – DELETE(H, x) xóa nút x khỏi heap H. ° Nhận xét: – Heap nhị thức không hổ trợ thao tác SEARCH hữu hiệu. – Do đó, các thao tác DECREASEKEY và DELETE cần một con trỏ đến nút cần được xử lý. 7.3.2004 Chương 5: Heap nhị thức 3
- Định nghĩa cây nhị thức 7.3.2004 Chương 5: Heap nhị thức 4
- Định nghĩa cây nhị thức ° Cây nhị thức Bk với k = 0, 1, 2,… là một cây có thứ tự được định nghĩa đệ quy: – Cây nhị thức B0 gồm một nút duy nhất. – Cây nhị thức Bk gồm hai cây nhị thức Bk 1 được liên kết với nhau theo một cách nhất định: ° Nút gốc của cây này là con bên trái nhất của nút gốc của cây kia. 7.3.2004 Chương 5: Heap nhị thức 5
- Đặc tính của cây nhị thức ° Lemma (Đặc tính của một cây nhị thức) Cây nhị thức Bk có các tính chất sau: 1. có 2k nút, 2. chiều cao của cây là k, k 3. có đúng nút t i ại độ sâu i với i = 0, 1,..., k 4. bậc của nút gốc của cây là k, nó lớn hơn bậc của mọi nút khác; ngoài ra nếu các con của nút gốc được đánh số từ trái sang phải bằng k 1, k 2,..., 0, thì nút con i là gốc của cây con Bi . k k! i i!(k i )! 7.3.2004 Chương 5: Heap nhị thức 6
- Đặc tính của cây nhị thức Chứng minh Dùng quy nạp theo k. Bước cơ bản: dễ dàng thấy các tính chất là đúng cho B0 Bước quy nạp: giả sử lemma là đúng cho Bk 1 . 1. Cây nhị thức Bk gồm hai Bk 1 nên Bk có 2k 1 + 2k 1 = 2k nút. 2. Do cách liên kết hai cây nhị thức Bk 1 với nhau để tạo nên Bk nên độ sâu tối đa của nút trong Bk bằng độ sâu tối đa của nút trong Bk 1 cộng thêm 1, tức là: (k 1) + 1 = k. 7.3.2004 Chương 5: Heap nhị thức 7
- Đặc tính của cây nhị thức Chứng minh (tiếp) 3. Gọi D(k, i) là số các nút tại độ sâu i của cây nhị thức Bk . Độ sâu i 1 Độ sâu i Bk 1 Bk 1 D(k , i) D (k 1, i ) D (k 1, i 1) k 1 k 1 i i 1 k i 7.3.2004 Chương 5: Heap nhị thức 8
- Đặc tính của cây nhị thức Chứng minh (tiếp) 4. Sử dụng hình sau. ... B0 B2 B1 Bk 2 Bk 1 Bk 1 7.3.2004 Chương 5: Heap nhị thức 9
- Đặc tính của cây nhị thức ° Hệ luận Bậc tối đa của một nút bất kỳ trong một cây nhị thức có n nút là lg n. 7.3.2004 Chương 5: Heap nhị thức 10
- Định nghĩa heap nhị thức ° Định nghĩa Một heap nhị thức H là một tập các cây nhị thức thỏa các tính chất heap nhị thức sau 1. Mọi cây nhị thức trong H là heapordered: mọi nút đều có khóa lớn hơn hay bằng khóa của nút cha của nó. 2. Với mọi số nguyên k 0 cho trước thì có nhiều nhất một cây nhị thức trong H mà gốc của nó có bậc là k. 7.3.2004 Chương 5: Heap nhị thức 11
- Tính chất của heap nhị thức ° Tính chất 1. Gốc của một cây trong một heap nhị thức chứa khóa nhỏ nhất trong cây. 2. Một heap nhị thức H với n nút gồm nhiều lắm là lg n + 1 cây nhị thức. Chứng minh 1. Hiển nhiên. 2. n có biểu diễn nhị phân duy nhất, biểu diễn này cần lg n + 1 bits, có dạng b lg n , b lg n 1 ,..., b0 sao cho lg n n bi 2i i 0 Cùng với định nghĩa 2, ta thấy cây nhị thức Bi xuất hiện trong H nếu và chỉ nếu bi = 1. 7.3.2004 Chương 5: Heap nhị thức 12
- Biểu diễn heap nhị thức 7.3.2004 Chương 5: Heap nhị thức 13
- Biểu diễn heap nhị thức Qui tắc trữ cho mỗi cây nhị thức trong một heap nhị thức: – Theo biểu diễn “Bên trái là con, bên phải là anh em” (leftchild, rightsibling representation) ° Mỗi nút x có một trường sau: – key[x]: trữ khóa của nút. ° Mỗi nút x có các con trỏ sau: – p[x]: trữ con trỏ đến nút cha của x. – child[x]: con trỏ đến con bên trái nhất của x. ° Nếu x không có con thì child[x] = NIL – sibling[x]: con trỏ đến anh em của x ở ngay bên phải x. ° Nếu x là con bên phải nhất của cha của nó thì sibling[x] = NIL. 7.3.2004 Chương 5: Heap nhị thức 14
- Biểu diễn heap nhị thức ° Ngoài ra mỗi nút x còn có một trường sau – degree[x]: bậc của x (= số các con của x) ° Các gốc của các cây nhị thức trong một heap nhị thức được tổ chức thành một danh sách liên kết, gọi là danh sách các gốc của heap nhị thức. – Khi duyệt danh sách các gốc của một heap nhị thức thì các bậc của các gốc theo thứ tự tăng dần. – Nếu x là một gốc thì sibling[x] chỉ đến gốc kế đến trong danh sách các gốc. ° Để truy cập một heap nhị thức H – head[H]: con trỏ chỉ đến gốc đầu tiên trong danh sách các gốc của H. ° head[H] = NIL nếu H không có phần tử nào. 7.3.2004 Chương 5: Heap nhị thức 15
- Tạo một heap nhị thức ° Thủ tục để tạo một heap nhị thức mới: MAKEBINOMIALHEAP – chiếm chổ cho và trả về một đối tượng H với head[H] = NIL. – có thời gian chạy là (1). 7.3.2004 Chương 5: Heap nhị thức 16
- Tìm khóa nhỏ nhất ° Thủ tục để tìm khóa nhỏ nhất trong một heap nhị thức H có n nút: BINOMIALHEAPMINIMUM – trả về một con trỏ đến nút có khóa nhỏ nhất. BINOMIALHEAPMINIMUM(H) 1 y NIL 2 x head[H] 3 min 4 while x NIL 5 do if key[x]
- Liên kết hai cây nhị thức ° Thủ tục để liên kết hai cây nhị thức: BINOMIALLINK – liên kết cây nhị thức Bk 1 có gốc tại nút y vào cây nhị thức Bk 1 có gốc tại nút z để tạo ra cây nhị thức Bk . Nút z trở nên gốc của một cây Bk . BINOMIALLINK(y, z) 1 p[y] z 2 sibling[y] child[z] 3 child[z] y 4 degree[z] degree[z] + 1 Thời gian chạy của thủ tục là O(1). 7.3.2004 Chương 5: Heap nhị thức 18
- Hòa nhập hai heap nhị thức ° Thủ tục để hòa nhập danh sách các gốc của heap nhị thức H1 và danh sách các gốc của heap nhị thức H2 : BINOMIALHEAPMERGE(H1 , H2 ) – hòa nhập các danh sách các gốc của H1 và H2 thành một danh sách các gốc duy nhất mà các bậc có thứ tự tăng dần. – nếu các danh sách các gốc của H1 và H2 có tổng cộng là m gốc, thì thời gian chạy của thủ tục là O(m). 7.3.2004 Chương 5: Heap nhị thức 19
- Hợp hai heap nhị thức ° Thủ tục để hợp hai heap nhị thức: BINOMIALHEAPUNION – hợp nhất hai heap nhị thức H1 và H2 và trả về heap kết quả. BINOMIALHEAPUNION(H1 , H2) 1 H MAKEBINOMIALHEAP() 2 head[H] BINOMIALHEAPMERGE(H1 , H2) 3 trả lại các đối tượng H1 và H2 nhưng giử lại các danh sách mà chúng chỉ vào 4 if head[H] = NIL 5 then return H 6 prevx NIL 7 x head[H] 8 nextx sibling[x] 7.3.2004 Chương 5: Heap nhị thức 20
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng Phân tích thiết kế hệ thống mạng - ThS. Lê Xuân Thành
52 p | 725 | 95
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 5 - TS. Đào Nam Anh
87 p | 193 | 31
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 3 - TS. Đào Nam Anh
60 p | 130 | 21
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 6 - TS. Đào Nam Anh
22 p | 128 | 16
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 1 - TS. Đào Nam Anh
78 p | 142 | 16
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 2 - TS. Đào Nam Anh
28 p | 136 | 15
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 4 - TS. Đào Nam Anh
12 p | 156 | 15
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 7 - TS. Đào Nam Anh
39 p | 111 | 13
-
Bài giảng Phân tích thiết kế giải thuật: Chương 2 - Trịnh Huy Hoàng
98 p | 116 | 11
-
Bài giảng Phân tích thiết kế hướng đối tượng - ThS. Lê Trung Hiếu
85 p | 89 | 9
-
Bài giảng Phân tích thiết kế giải thuật: Chương 1 - Trịnh Huy Hoàng
72 p | 119 | 8
-
Bài giảng Phân tích thiết kế hướng đối tượng: Chương 5 - Lê Thị Minh Nguyện
11 p | 101 | 8
-
Bài giảng Phân tích thiết kế giải thuật - Chương 37: Giải thuật xấp xỉ
21 p | 111 | 7
-
Bài giảng Phân tích thiết kế giải thuật: Chương 4 - Trịnh Huy Hoàng
90 p | 108 | 7
-
Bài giảng Phân tích thiết kế hệ thống thông tin: Bài 11 - TS. Trần Mạnh Tuấn
29 p | 54 | 7
-
Bài giảng Phân tích thiết kế hệ thống thông tin: Bài 9 - TS. Trần Mạnh Tuấn
46 p | 61 | 6
-
Bài giảng Phân tích thiết kế hướng đối tượng: Chương 4 - Lê Thị Minh Nguyện
14 p | 88 | 5
-
Bài giảng Phân tích thiết kế và giải thuật - Chương 1: Kỹ thuật phân tích giải thuật
59 p | 22 | 3
Chịu trách nhiệm nội dung:
Nguyễn Công Hà - Giám đốc Công ty TNHH TÀI LIỆU TRỰC TUYẾN VI NA
LIÊN HỆ
Địa chỉ: P402, 54A Nơ Trang Long, Phường 14, Q.Bình Thạnh, TP.HCM
Hotline: 093 303 0098
Email: support@tailieu.vn