Cách Vẽ Lại Cây Nhị Phân Tìm Kiếm Từ Kết Quả Duyệt
Có thể bạn quan tâm
Thường có 3 cách duyệt cơ bản là tiền thứ tự (NLR), trung thứ tự (LNR) và hậu thứ tự (LRN). Với kết quả duyệt kiểu NLR và LRN ta có thể vẽ lại cây ban đầu dễ dàng. Còn với LNR, ta không tìm được Node gốc nên không thể vẽ lại cây.
Nguyên tắc chung để vẽ lại cây- Tìm Node gốc.
- Tìm đoạn lớn hơn Node gốc sẽ là nhánh phải, đoạn nhỏ hơn Node gốc sẽ là nhánh trái. (Vì nguyên tắc của cây nhị phân tìm kiếm, Node gốc sẽ có khóa lớn hơn tất cả Node con nhánh bên trái và nhỏ hơn tất cả các Node ở nhánh phải)
- Với mỗi đoạn vừa tìm được, tìm Node gốc của từng đoạn và tiếp tục tìm đoạn lớn hơn và nhỏ hơn Node gốc.
Đó là nguyên tắc chung để vẽ lại cây. Với cách duyệt NLR, ta luôn có Node gốc là Node đầu tiên của dãy kết quả, còn cách duyệt LRN là Node cuối cùng.
Ví dụ: Cho kết quả duyệt LRN: 5 3 7 9 8 11 6 20 19 37 25 21 15 12
Nhìn vào kết quả duyệt ta dễ dàng thấy 12 sẽ là Node gốc. Đoạn 5 đến 6 sẽ là nhánh trái và 20 đến 15 sẽ là nhánh phải.
Tiếp tục xét đoạn trái, ta thấy số 6 sẽ là Node gốc tiếp theo, tìm đoạn nhỏ hơn số 6 là [5,3] sẽ là nhánh trái, đoạn [7,11] sẽ là nhánh phải.
Cứ tiếp tục xét như thế đến hết ta sẽ vẽ được nhánh trái của cây.
Giờ ta xét nhánh phải với nguyên tắc tương tự. 15 sẽ là Node gốc tiếp theo, vì không có số nào nhỏ hơn 15 ở đoạn phải nên những số còn lại hoàn toàn nằm ở nhánh phải của 15. Xét tiếp đoạn đó tương tự ta sẽ vẽ được nhánh phải.
Các bạn hãy thử sức với các bài tập sau nhé!
Vẽ lại cây nhị phân tìm kiếm từ kết quả duyệt:
NLR: 7 6 4 15 13 9 14 30 31
Từ khóa » Duyệt Lrn
-
Duyệt Cây Nhị Phân Tìm Kiếm - Freetuts
-
Duyệt Cây NLR LNR LRN - YouTube
-
[Cây Nhị Phân Tìm Kiếm] Bài 6. Duyệt LRN Cây Nhị Phân ... - YouTube
-
Phần 1 - Cây Nhị Phân Tìm Kiếm — Giải Thuật Lập Trình
-
Duyệt Cây Nhị Phân Tìm Kiếm Trong C/C++ - Lập Trình Từ Đầu
-
Cách Vẽ Lại Cây Nhị Phân Tìm Kiếm Từ Kết Quả Duyệt - Cùng Lập Trình
-
Cây Nhị Phân Trong C++ | TopDev
-
Các Thuật Toán Duyệt Cây Nhị Phân Cài đặt Thuật Toán Duyệt Qua Cây ...
-
Giới Thiệu Về Cấu Trúc Cây (tiếp Theo) | Facebook
-
Các Thao Tác Cơ Bản Trên Cây Nhị Phân (Binary Tree) - Góc Học IT
-
[PDF] CẤU TRÚC DỮ LIỆU & GIẢI THUẬT 1 CÂY (TREE)
-
Vẽ Lại Cây Nhị Phân Tìm Kiếm Từ Kết Quả Duyệt - Viết Linh Tinh
-
Duyệt Cây Nhị Phân Theo Chiều Rộng _Lập Trình C++
-
Cây Nhị Phân - SlideShare