intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Bài giảng Toán rời rạc: Chương 8 - TS. Nguyễn Viết Đông

Chia sẻ: Minh Vũ | Ngày: | Loại File: PDF | Số trang:29

116
lượt xem
7
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

 Bài giảng "Toán rời rạc - Chương 8: Cây" do TS. Nguyễn Viết Đông biên soạn cung cấp cho người học các kiến thức: Định nghĩa và tính chất, cây khung ngắn nhất, cây có gốc, phép duyệt cây. Mời các bạn cùng tham khảo nội dung chi tiết.

Chủ đề:
Lưu

Nội dung Text: Bài giảng Toán rời rạc: Chương 8 - TS. Nguyễn Viết Đông

  1. Cây Cây 1. ĐN và tính chất Biên soạn: TS.Nguyễn Viết Đông 2. Cây khung ngắn nhất 3. Cây có gốc 4. Phép duyệt cây 2 Định nghĩa và tính chất Định nghĩa và tính chất Định nghĩa Cây. 1 a) Cho G là đồ thị vô hướng. G được gọi là một 2 4 cây nếu G liên thông và không có chu trình 3 sơ cấp. 5 9 10 8 6 7 b) Rừng là đồ thị mà mỗi thành phần liên 15 thông của nó là một cây. 11 12 13 14 16 17 3 4 1
  2. Định nghĩa và tính chất Định nghĩa và tính chất Điều kiện cần và đủ. 1 Cho T là đồ thị vô hướng có n đỉnh. Các phát biểu sau đây là tương đương: 2 4 3 i. T là cây. 10 ii. T liên thông và có n-1 cạnh. 5 9 8 iii. T không có chu trình sơ cấp và có n-1 cạnh . 6 7 iv. T liên thông và mỗi cạnh là một cầu. 11 12 13 14 15 16 17 v. Giữa hai đỉnh bất kỳ có đúng một đường đi sơ cấp nối chúng với nhau. vi. T không có chu trình sơ cấp và nếu thêm vào một cạnh giữa hai đỉnh không kề nhau thì có một chu trình sơ cấp duy nhất. 5 6 Breadth-first Search Algorithm .Thuật toán ưu tiên Định nghĩa và tính chất chiều rộng Cho G là đồ thị liên thông với tập đỉnh {v1, v2, …, vn} Định nghĩa cây khung. Bước 0:thêm v1 như là gốc của cây rỗng. Bước 1: thêm vào các đỉnh kề v1 làm con của nó và các Cho G = (V,E) là đồ thị vô hướng. cạnh nối v1 với chúng. T là đồ thị con khung của G. Những đỉnh này là đỉnh mức 1 trong cây. Bước 2: đối với mọi đỉnh v mức1, thêm vào các cạnh Nếu T là một cây thì T được gọi là cây khung(hay kề với v vào cây sao cho không tạo nên chu trình đơn. cây tối đại, hay cây bao trùm) của đồ thị G. Thu được các đỉnh mức 2. ……………………………………………………. Thuật toán tìm cây khung. Tiếp tục quá trình này cho tới khi tất cả các đỉnh của đồ thị được ghép vào cây. CâyT thu được là cây khung của đồ thị. 7 2
  3. Ví dụ. Xét đồ thị liên thông G. b c l e a b c l a e e f f d b d e f g i d b d f g i c h a k h i j g j h i j Chọn e làm gốc m k  Thêm a và c làm con của b, m k  h là con duy nhất của d, Các đỉnh kề với e là con của nó.  g và j là con của f, Các đỉnh mức 1 là: b, d, f, i  k là con duy nhất của i, Các đỉnh mức 2 là: a, c, h, g, j, k Depth-first Search Algorithm b c l e (Thuật toán ưu tiên chiều sâu) a Cho G là đồ thị liên thông với tập đỉnh{v1, v2, …, vn} d e f b d f Chọn một đỉnh tùy ý của đồ thị làm gốc. Xây dựng g i đường đi từ đỉnh này bằng cách lượt ghép các cạnh sao cho mỗi cạnh mới ghép sẽ nối đỉnh cuối cùng trên a c h k đường đi với một đỉnh còn chưa thuộc đường đi.Tiếp tục h i j g j ghép thêm cạnh vào đường đi chừng nào không thể thêm được nữa. Nếu đường đi qua tất cả các đỉnh của đồ thị m k thì cây do đường đi này tạo nên là cây khung. Nếu chưa l m thì lùi lại đỉnh trước đỉnh cuối cùng của đường đi và xây dựng đường đi mới xuất phát từ đỉnh này đi qua các đỉnh Cuối cùng thêm l và m là con của g và k tương còn chưa thuộc đường đi. Nếu điều đó không thể làm ứng được thì lùi thêm một đỉnh nữa trên đường đi, tức là lùi hai đỉnh trên đường đi và thử xây dựng đường đi mới. Các đỉnh mức 3 là: l, m 3
  4. Ví dụ. Tìm cây bao trùm của đồ thị G. d i j f a d i j f a g d f g h e c f e h k c h b k c e h k i b k g j b a g j  Thêm i làm con thứ hai của h và lùi về f. Giải. Bắt đầu chọn đỉnh f làm gốc và  Lại thêm các hậu duệ của f : d, e, c, a Thêm các hậu duệ của f : g, h, k, j  Lùi về c và thêm b làm con thứ hai của nó . Lùi về k không thêm được cạnh nào, tiếp tục lùi về h Cây thu được là cây khung của đồ thị đã cho Định nghĩa và tính chất Cây khung ngắn nhất Định nghĩa Cây khung ngắn nhất. Thuật toán tìm cây khung ngắn nhất a)Thuật toán Kruscal Cho G là đồ thị có trọng số. Cây khung T của G được gọi là cây khung ngắn nhất (cây tối Cho G là đồ thị liên thông, có trọng số, n đỉnh. đại ngắn nhất,cây bao trùm ngắn nhất, cây Bước 1.Trước hết chọn cạnh ngắn nhất e1 trong các cạnh khung tối tiểu) nếu nó là cây khung của G mà của G. có trọng lượng nhỏ nhất. Bước 2. Khi đã chọn k cạnh e1,e2,…ek thì chọn tiếp cạnh ek+1 ngắn nhất trong các cạnh còn lại của G sao cho không tạo thành chu trình với các cạnh đã chọn trước. 15 Bước 3. Chọn đủ n-1 cạnh thì dừng. 16 4
  5. Cây khung ngắn nhất Cây khung ngắn nhất 6 3 a u d a 1 4 4 S1 1 b b a 6 u 3 d 6 8 1 4 4 b 6 8 c 17 c 18 Cây khung ngắn nhất Cây khung ngắn nhất 3 3 a u d a u d 1 4 1 6 6 a u 3 d b a u 3 d b 4 4 1 4 1 4 b b 6 6 S2 8 S3 8 c 19 c 20 5
  6. Cây khung ngắn nhất Thuật toán Krusal 1 A 8 B 3 5 3 C a u d F 1 4 3 1 6 1 4 E 2 D b a 6 u 3 d 6 AE DC AC ED BD AF AD BC FE AB 1 4 4 1 1 1 2 3 3 4 5 6 8 b 6 S4 c 8 0. S0={} c 21 22 Thuật toán Krusal Thuật toán Krusal 1 1 A 8 B A 8 B 3 5 3 5 C C F 1 4 3 F 1 4 3 1 1 6 6 E 2 D E 2 D AE DC AC ED BD AF AD BC FE AB AE DC AC ED BD AF AD BC FE AB 1 1 1 2 3 3 4 5 6 8 1 1 1 2 3 3 4 5 6 8 0. S0={} 1. S1= {AE} 1. S1=S0 + AE = {AE} 2. S2=S1 + DC = {AE,DC} 23 24 6
  7. Thuật toán Krusal Thuật toán Krusal 1 1 A 8 B A 8 B 3 5 3 5 C C F 1 4 3 F 1 4 3 1 1 6 6 E 2 D E 2 D AE DC AC ED BD AF AD BC FE AB AE DC AC ED BD AF AD BC FE AB 1 1 1 2 3 3 4 5 6 8 1 1 1 2 3 3 4 5 6 8 3. S3= {AE,DC,AC} 4. S4= {AE,DC,AC,BD} 4. S4=S3 + BD= {AE,DC,AC,BD} 5. S5=S4 + AF= {AE,DC,AC,BD,AF} 25 26 Thuật toán Krusal Ví dụ 1 A A B 11 3 7 10 C F 1 3 B 8 G 9 D 1 3 5 E D E 10 12 8 Kết luận: S5= {AE,DC,AC,BD,AF} 4 là cây bao trùm tối tiểu cần tìm C 10 F Trọng lượng: 9 28 27 7
  8. Cây khung ngắn nhất Cây khung ngắn nhất Thuật toán tìm cây khung ngắn nhất Thuật toán tìm cây khung ngắn nhất b)Thuật toán Prim. 6 3 d Bước 1. Chọn 1 đỉnh bất kỳ v1 để có cây T1 chỉ gồm 1 a u đỉnh. 1 4 4 Bước 2. Khi đã chọn cây Tk thì chọn tiếp cây b Tk+1 = Tk ek+1. Trong đó ek+1 là cạnh ngắn nhất trong 6 các cạnh có một đầu mút thuộc Tk và đầu mút kia 8 không thuộc Tk Bước 3. Chọn được cây Tn thì dừng. c 29 30 Cây khung ngắn nhất Cây khung ngắn nhất d a 6 u 3 d a 6 u 3 d 6 1 4 1 4 4 4 b b 6 6 T1 c 8 T2 c 8 c 31 c 32 8
  9. Cây khung ngắn nhất Cây khung ngắn nhất 3 3 u d u d 4 a 6 u 3 d b a 6 u 3 d 6 6 1 4 1 4 4 4 b b 6 6 T3 c 8 T4 c 8 c 33 c 34 Cây khung ngắn nhất Thuật toán Prim 1 A 8 B 3 5 3 C a u d 3 F 1 4 4 1 1 6 E 2 D b a 6 u 3 d 6 1 4 4 b 6 T5 c 8 c 35 36 9
  10. Thuật toán Prim Thuật toán Prim 1 1 A 8 B A 8 B 3 5 3 5 C C F 1 4 3 F 1 4 3 1 1 6 6 E 2 D E 2 D 37 38 Thuật toán Prim Thuật toán Prim 1 1 A 8 B A 8 B 3 5 3 5 C C F 1 4 3 F 1 4 3 1 1 6 6 E 2 D E 2 D 39 40 10
  11. Thuật toán Prim Thuật toán Prim 1 1 A 8 B A 8 B 3 5 3 5 C C F 1 4 3 F 1 4 3 1 1 6 6 E 2 D E 2 D Cây T5 = {AC, AE,CD,AF,DB} là cây bao trùm tối tiểu cần tìm với w(T5) = 9 41 42 Ví dụ Cây khung ngắn nhất A Đề thi 2004 Hãy trình bày thuật toán tìm cây khung ngắn nhất 7 11 10 của G chứa cạnh 58 nhưng không chứa cạnh 26 B 8 G D 9 3 5 2 9 1 2 3 E 10 12 8 3 14 7 11 4 4 1 4 5 6 5 6 8 12 C 10 F 7 8 9 13 10 43 44 11
  12. Cây khung ngắn nhất Cây có gốc Giải Định nghĩa.  Đặt G’= G -26 thì cây khung phải tìm là ở trong Cho T là một cây. Chọn một đỉnh r của cây gọi là G’. Đầu tiên chọn cạnh 58 sau đó áp dụng Kruscal như thông thường gốc . Vì có đường đi sơ cấp duy nhất từ gốc tới 2 9 mỗi đỉnh của đồ thị nên ta định hướng mỗi cạnh là 1 2 3 7 2 9 hướng từ gốc đi ra . Cây cùng với gốc sinh ra một 1 2 3 1 4 4 5 6 14 7 11 đồ thị có hướng gọi là cây có gốc 6 8 4 4 5 1 6 Trong một cây có gốc r thì deg-(r) = 0, 6 5 8 12 7 10 9 7 8 9 deg-(v) =1với mọi đỉnh không phải là gốc. 13 10 45 46 Cây có gốc Cây có gốc Định nghĩa Cho cây có gốc r. ----------------------------------level 0  Gốc r được gọi là đỉnh mức 0 (level 0). ---------------------------------------level 1  Các đỉnh kề với gốc r được xếp ở phía dưới gốc và gọi là đỉnh mức 1(level 1). ----------------------------------------------level 2  Đỉnh sau của đỉnh mức 1(xếp phía dưới đỉnh mức1)gọi là đỉnh mức 2. …… --------------------------------------------------level 3  Level (v) = k  đường đi từ gốc r đến v qua k cung. ---------------------------------------------level 4  Độ cao của cây là mức cao nhất của các đỉnh. 47 48 12
  13. Cây có gốc Cây có gốc Định nghĩa Định nghĩa Cho cây có gốc r Cho cây có gốc r a) Nếu uv là một cung của T thì u được gọi là cha d) Nếu có đường đi v1v2…vk thì v1, v2,.., vk-1 gọi là của v, còn v gọi là con của u. tổ tiên của vk. Còn vk gọi là hậu duệ của v1, v2,.., vk-1. b) Đỉnh không có con gọi là lá(hay đỉnh ngoài). Đỉnh không phải là lá gọi là đỉnh trong. e) Cây con tại đỉnh v là cây có gốc là v và tất cả các đỉnh khác là mọi hậu duệ của v trong cây T c) Hai đỉnh có cùng cha gọi là anh em. đã cho. 49 50 Cây có gốc Cây có gốc Định nghĩa 1 Cho T là cây có gốc. 2 4 a) T được gọi là cây k-phân nếu mỗi đỉnh của T có 3 nhiều nhất là k con. 5 9 10 8 b) Cây 2-phân được gọi là cây nhị phân. 6 7 15 c) Cây k-phân đủ là cây mà mọi đỉnh trong có 11 12 13 14 16 17 đúng k con. d) Cây k- phân với độ cao h được gọi là cân đối nếu các lá đều ở mức h hoặc h – 1 . 51 52 13
  14. Cây có gốc Cây có gốc Định nghĩa Định nghĩa Cho T là cây nhị phân có gốc là r. Ta có thể biểu Độ dài đường đi trong và độ dài đường đi ngoài diễn T như hình vẽ dưới với hai cây con tại r là TL và TR ,chúng lần lượt được gọi là cây con bên Cho T là cây nhị phân đủ. trái và cây con bên phải của T. a) Độ dài đường đi trong là tổng tất cả các mức r của các đỉnh trong, ký hiệu IP(T). b) Độ dài đường đi ngoài là tổng tất cả các mức của các lá, ký hiệu EP(T). TL TR 53 54 Cây có gốc Cây có hướng Định lí IP(T) = ? 1 EP(T) = ? 2 3 Cho T là cây nhị phân đủ với k đỉnh trong và s lá. 7 4 5 6 Ta có: 8 9 10 11 s = k+1 và EP=IP+2k 55 56 14
  15. Cây có hướng Phép duyệt cây(Tree travesal) Định nghĩa Định nghĩa Cho T là cây nhị phân không đủ. Lập T’ là cây có Duyệt cây là liệt kê tất các đỉnh của cây được bằng cách sau: theo một thứ tự nào đó thành một dãy, mỗi đỉnh chỉ xuất hiện một lần . i. Thêm vào mỗi lá của T hai con. ii. Thêm vào v một con nếu v là đỉnh trong của T mà chỉ có một con. Ta đặt: IP(T) :=IP(T’)& EP(T):=EP(T’) 57 58 Phép duyệt cây Preorder Traversal: J E A H T M Y Phép duyệt tiền thứ tự Visit first. (Preoder traversal) ROOT ‘J’ 1. Đến gốc r. ‘T’ ‘E’ 2. Dùng phép duyệt tiền thứ tự để duyệt các cây con T1 rồi cây con T2 …từ trái sang ‘A’ ‘H’ ‘M’ ‘Y’ phải. Visit left subtree second Visit right subtree last 59 60 15
  16. Phép duyệt cây Preorder Traversal: J E A H T M Y Visit first. Phép duyệt hậu thứ tự ROOT (Posoder traversal). ‘J’ 1. Dùng phép duyệt hậu thứ tự để lần lượt ‘T’ duyệt cây con T1, T2,…. từ trái sang phải. ‘E’ 2. Đến gốc r. ‘A’ ‘H’ ‘M’ ‘Y’ Visit left subtree Visit right subtree in Preorder in Preorder 61 62 Postorder Traversal: A H E M Y T J Postorder Traversal: A H E M Y T J ROOT Visit last ROOT Visit last ‘J’ ‘J’ ‘T’ ‘T’ ‘E’ ‘E’ ‘M’ ‘Y’ ‘M’ ‘Y’ ‘A’ ‘H’ ‘A’ ‘H’ Visit left subtree first Visit right subtree second Visit left subtree Visit right subtree 63 in Postorder in Postorder 64 16
  17. Phép duyệt cây Inorder Traversal: A E H J M T Y Phép duyệt trung thứ tự cho cây nhị Visit second phân (Inorder traversal) ROOT ‘J’ 1. Duyệt cây con bên trái TL theo trung thứ tự. ‘E’ ‘T’ 2. Đến gốc r. ‘A’ ‘H’ ‘M’ ‘Y’ 3. Duyệt cây con bên phải theo trung thứ tự. Visit left subtree first Visit right subtree last 65 66 Inorder Traversal: A E H J M T Y Phép duyệt cây Visit second 1 preoder ROOT 4 2 3 ‘J’ 10 5 9 8 ‘T’ 6 7 ‘E’ 11 12 13 15 16 17 14 ‘M’ ‘Y’ ‘A’ ‘H’ Visit left subtree Visit right subtree Preoder:1,2,5,11,12,13,14,3,6,7,4,8,9,10,15,16,17 in Inorder in Inorder 67 68 17
  18. Phép duyệt cây Phép duyệt cây ... r 1 a b posoder Inoder e 2 4 c d 3 f g i 10 h 5 9 j n m 6 7 8 p k 11 12 13 14 15 16 17 s t u q Inoder :p,j,q,f,c,k,g,a,d,r,b,h,s,m,e,i,t,n,u Posoder:11,12,13,14,5,2,6,7,3,8,9,15,16,17,10,4,1 69 70 Cây nhị phân của biểu thức Định nghĩa Gốc Cây nhị phân của biểu thức là cây nhị phân mà 1. Mỗi biến số được biểu diễn bởi một lá. ‘-’ 2. Mỗi đỉnh trong biểu diễn một phép toán với các thành tố là cây con tại đỉnh ấy. ‘8’ ‘5’ 3. Cây con bên trái và bên phải của một đỉnh trong biểu diễn cho biểu thức con, giá trị của chúng là thành tố mà ta áp dụng cho phép toán tại gốc của cây con. INORDER TRAVERSAL: 8 - 5 có giá trị 3 PREORDER TRAVERSAL: - 8 5 POSTORDER TRAVERSAL: 8 5 - 71 72 18
  19. Cây nhị phân của biểu thức Cây nhị phân của biểu thức ‘*’ ‘*’ ‘*’ ‘+’ ‘3’ ‘+’ ‘3’ ‘4’ ‘2’ ‘4’ ‘2’ Kết quả? Dạng trung tố, tiền tố, hậu tố? ( 4 + 2 ) * 3 = 18 73 74 Cây nhị phân của biểu thức Giải thích ‘*’ Để có biểu thức theo ký pháp Ba lan, ta duyệt cây nhị phân của biểu thức bằng phép duyệt ‘+’ ‘3’ tiền thứ tự. Thực hiện biểu thức từ phải sang trái: ‘4’ ‘2’ Bắt đầu từ bên phải, khi gặp một phép toán thì phép toán này được thực hiện cho 2 thành tố Infix: ((4+2)*3) ngay bên phải nó, kết quả này là thành tố cho Prefix: * + 4 2 3 Ký pháp Ba lan : từ phải sang trái Postfix: 4 2 + 3 * Ký pháp BL đảo : từ trái sang phải phép toán tiếp theo. 75 76 19
  20. Giải thích Ví dụ Để có biểu thức theo ký pháp Ba lan ngược, ta ‘*’ duyệt cây nhị phân của biểu thức bằng phép duyệt hậu thứ tự. ‘-’ ‘/’ Thực hiện biểu thức từ trái sang phải: Bắt đầu từ bên trái, khi gặp một phép toán thì ‘8’ ‘5’ ‘+’ ‘3’ phép toán này được thự hiện cho 2 thành tố ngay bên trái nó, kết quả này là thành tố cho ‘4’ ‘2’ phép toán tiếp theo. Kết quả của infix, prefix, postfix? 77 78 ‘*’ ‘*’ ‘-’ ‘/’ ‘-’ ‘/’ ‘8’ ‘5’ ‘+’ ‘3’ ‘8’ ‘5’ ‘+’ ‘3’ ‘4’ ‘2’ ‘4’ ‘2’ Infix: ((8-5)*((4+2)/3)) Infix: ((8-5)*((4+2)/3)) Prefix: *-85 /+423 Prefix: * - 8 5 / + 4 2 3 Thực hiện từ phải sang Postfix: 85- 42+3/* Postfix: 85- 42+3/* Thực hiện từ trái sang 79 80 20
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2