Duyệt Cây – Wikipedia Tiếng Việt
Trong khoa học máy tính, duyệt cây là việc lần lượt thăm các đỉnh của cây theo một thứ tự nào đó. Các cây nói trong bài này là cây có gốc.
Dưới đây trình bày một số thuật toán duyệt cây thông dụng.
Duyệt cây nhị phân
[sửa | sửa mã nguồn]Khi xét một cây nhị phân, mỗi đỉnh cùng với các đỉnh đứng sau nó là gốc của một cây con. Ta xét một đỉnh A là đỉnh trong của cây nhị phân. Theo thứ tự người ta xem xét thứ tự thăm đỉnh A so với việc thăm hai con của nó là thăm A trước rồi hai con sau, thăm A xen giữa việc thăm hai con, thăm A sau thi thăm hai con:
- A, con trái, con phải
- Con trái, A, con phải
- Con trái, con phải, A
Tất nhiên nút không có con nào thì việc thăm con không diễn ra. Còn nếu con trái hoặc con phải của A lại là gốc của một cây con, thì việc thăm thay bằng việc duyệt cây con có gốc tại đó.
Từ đó có các phương pháp duyệt tiền thứ tự, trung thứ tự, hậu thứ tự đối với cây nhị phân có gốc tại đỉnh A như sau
Duyệt tiền thứ tự cây con gốc A
[sửa | sửa mã nguồn]- Nếu Cây là rỗng Return
- Thăm A
- Duyệt tiền thứ tự cây con gốc trái
- Duyệt tiền thứ tự cây con gốc phải
Duyệt trung thứ tự cây con gốc A
[sửa | sửa mã nguồn]- Nếu Cây là rỗng Return
- Duyệt trung thứ tự cây con gốc trái
- Thăm A
- Duyệt trung thứ tự cây con gốc phải
Duyệt hậu thứ tự cây con gốc A
[sửa | sửa mã nguồn]- Nếu Cây là rỗng Return
- Duyệt hậu thứ tự cây con gốc trái
- Duyệt hậu thứ tự cây con gốc phải
- Thăm A
Ví dụ
[sửa | sửa mã nguồn]Giả sử có cây nhị phân sau
A / \ B C / \ / \ D E F G- Duyệt tiền thứ tự với cây này diễn ra tuần tự như sau
- Thăm A, Duyệt cây gốc B, Duyệt cây gốc C
- Thăm A, Thăm B, Thăm D, Thăm E, Thăm C, Thăm F, Thăm G
- Duyệt trung thứ tự với cây này diễn ra tuần tự như sau
- Duyệt cây gốc B, Thăm A, Duyệt cây gốc C
- Thăm D, Thăm B, Thăm E, Thăm A, Thăm F, Thăm C, Thăm G
- Duyệt hậu thứ tự với cây này diễn ra tuần tự như sau
- Duyệt cây gốc B, Duyệt cây gốc C, Thăm A
- Thăm D, Thăm E, Thăm B, Thăm F, Thăm G, Thăm C, Thăm A
Duyệt cây tổng quát
[sửa | sửa mã nguồn]Nếu tại gốc A của cây có các con từ trái sang phải là thì quá trình duyệt tiền thứ tự, trung và hậu thứ tự như sau
Duyệt tiền thứ tự
[sửa | sửa mã nguồn]- Thăm A
- Lần lượt duyệt các cây con gốc
Duyệt trung thứ tự
[sửa | sửa mã nguồn]- Duyệt cây con gốc
- Thăm A
- Lần lượt duyệt các cây con gốc
Duyệt hậu thứ tự
[sửa | sửa mã nguồn]- Lần lượt duyệt các cây con gốc
- Thăm A
Tuy nhiên người ta ít xem xét việc duyệt trung thứ tự của cây tổng quát
Duyệt theo mức
[sửa | sửa mã nguồn]Một phương pháp duyệt cây khác là duyệt theo mức. Bắt đầu duyệt từ gốc (đỉnh mức 0), rồi duyệt các con của gốc từ trái sang phải (các đỉnh mức 1), tiếp đến là các đỉnh mức 2,...
Giả mã
[sửa | sửa mã nguồn]Giả sử có một cây nhị phân mà cấu trúc mỗi nút của nó chứa một giá trị value và các tham chiếu left và right trỏ tới hai con của nút đó. Ta có thể viết các hàm sau:
Duyệt tiền thứ tự
[sửa | sửa mã nguồn](pre-order (prefix) traversal)
visit(node) print node.value if node.left != null then visit(node.left) if node.right != null then visit(node.right)Duyệt hậu thứ tự
[sửa | sửa mã nguồn](post-order (postfix) traversal)
visit(node) if node.left != null then visit(node.left) if node.right != null then visit(node.right) print node.valueDuyệt trung thứ tự
[sửa | sửa mã nguồn](in-order (infix) traversal)
visit(node) if node.leftt!= null then visit(node.left) print node.value if node.rightg!= null then visit(node.right) // In phan tu tu be den lonCây nhị phân tương đương
[sửa | sửa mã nguồn]Lưu trữ cấu trúc cây nhị phân
[sửa | sửa mã nguồn]Để biểu diễn cây nhị phân ta dùng cấu trúc Nút (Node). Mỗi Nút là một đỉnh của cây, gồm ba trường, một trường chứa thông tin về nút đó. Hai trường và trỏ tới các nút con của đỉnh đó. Ngoài ra còn một con trỏ là trỏ tới nút gốc.
Cây nhị phân ở trong bài có thể biểu diễn như sau:
Root=A A.Value="A",A.Left=B;A.Right=C B.Value="B",B.Left=D;B.Right=E C.Value="C",C.Left=F;C.Right=G D.Value="D",D.Left=Null;D.Right=Null E.Value="E",E.Left=Null;E.Right=Null F.Value="F",F.Left=Null;F.Right=Null G.Value="G",G.Left=Null;G.Right=NullChú ý: Phân biệt ký hiệu A, B,... chỉ nút và "A","B",... chỉ giá trị nút
Lưu trữ cấu trúc cây tổng quát
[sửa | sửa mã nguồn]Khi biểu diễn cấu trúc cây tổng quát, vì mỗi nút có thể có nhiều con, số con có thể khác nhau, nên ta không dùng cho mỗi nút con một liên kết đến nút cha mà với mỗi nút vẫn chỉ dành hai liên kết, một liên kết (trường ) trỏ đến nút con đầu bên trái của nó, một liên kết (trường )trỏ đến nút cùng cha kề bên phải nó. Nếu coi liên kết trường như liên kết , liên kết như liên kết ta có một cây nhị phân tương đương với cây tổng quát.
Ví dụ
[sửa | sửa mã nguồn]- Cây tổng quát
- Cây nhị phân tương đương
- Lưu trữ của cây tổng quát như sau
Tham khảo
[sửa | sửa mã nguồn]Liên kết ngoài
[sửa | sửa mã nguồn]Tiếng Anh:
- The Adjacency List Model for Processing Trees with SQL
- Storing Hierarchical Data in a Database with traversal examples in PHP
- Managing Hierarchical Data in MySQL Lưu trữ 2011-06-06 tại Wayback Machine
Từ khóa » Duyệt Tiền Tự
-
Duyệt Cây Trong Cấu Trúc Dữ Liệu Và Giải Thuật
-
Duyệt Cây Trong Cấu Trúc Dữ Liệu Và Giải Thuật
-
Duyệt Cây Và Thứ Tự Duyệt Cây - TEK4
-
Duyệt Cây Trong Cấu Trúc Dữ Liệu Và Giải Thuật - Dolatrees
-
Cây Nhị Phân Trong C++ | TopDev
-
Duyệt Cây Nhị Phân: Tiền Tự (Pre-order), Trung Tự (In ... - YouTube
-
Giải Thuật Và Lập Trình - C: IV. Cây Nhị Phân (BINARY TREES)
-
Giải Thuật Và Lập Trình - C: BÀI TẬP | V1Study
-
BINTREE - Duyệt Cây Nhị Phân - VNOI
-
Duyệt Cây Nhị Phân Tìm Kiếm - Freetuts
-
Thứ Tự Các Nút Trong Cây Các Thứ Tự Duyệt Cây Quan Trọng Cây Có ...
-
Các Phép Duyệt Cây Nhị Phân - Giáo Trình Cấu Trúc Dữ Liệu Và Giải Thuật
-
[PDF] CÁC KIỂU DỮ LIỆU TRỪU TƯỢNG CƠ BẢN CẤU TRÚC DỮ LIỆU ...
-
Duyệt Cây – Du Học Trung Quốc 2022 - Wiki Tiếng Việt