โครงสร้างข้อมูลและอัลกอริทึม - Tree Traversal
Traversal เป็นกระบวนการในการเยี่ยมชมโหนดทั้งหมดของต้นไม้และอาจพิมพ์ค่าของมันด้วย เนื่องจากโหนดทั้งหมดเชื่อมต่อผ่านขอบ (ลิงค์) เรามักจะเริ่มต้นจากโหนดรูท (หัว) นั่นคือเราไม่สามารถสุ่มเข้าถึงโหนดในทรีได้ มีสามวิธีที่เราใช้ในการสำรวจต้นไม้ -
- In-order Traversal
- พรีออเดอร์ Traversal
- Post-order Traversal
โดยทั่วไปเราสำรวจต้นไม้เพื่อค้นหาหรือค้นหารายการหรือคีย์ที่กำหนดในแผนภูมิหรือเพื่อพิมพ์ค่าทั้งหมดที่มีอยู่
In-order Traversal
ในวิธีการข้ามผ่านนี้ทรีย่อยด้านซ้ายจะถูกเยี่ยมชมก่อนจากนั้นจึงไปที่รูทและตามมาในแผนผังย่อยด้านขวา เราควรจำไว้เสมอว่าทุกโหนดอาจเป็นตัวแทนของทรีย่อยเอง
หากมีการข้ามต้นไม้ไบนารี in-orderผลลัพธ์จะสร้างค่าคีย์ที่เรียงลำดับจากน้อยไปหามาก
เริ่มจาก Aและตามลำดับตามลำดับเราจะย้ายไปที่ทรีย่อยด้านซ้าย B. Bยังถูกส่งผ่านตามลำดับ กระบวนการดำเนินต่อไปจนกว่าจะมีการเยี่ยมชมโหนดทั้งหมด ผลลัพธ์ของการส่งผ่านตามลำดับของต้นไม้นี้จะเป็น -
D → B → E → A → F → C → G
อัลกอริทึม
Until all nodes are traversed −
Step 1 − Recursively traverse left subtree.
Step 2 − Visit root node.
Step 3 − Recursively traverse right subtree.
พรีออเดอร์ Traversal
ในวิธีการข้ามผ่านนี้โหนดรูทจะถูกเยี่ยมชมก่อนจากนั้นทรีย่อยด้านซ้ายและสุดท้ายคือทรีย่อยด้านขวา
เริ่มจาก Aและหลังจากการสั่งซื้อล่วงหน้าเราไปเยี่ยมชมครั้งแรก A แล้วย้ายไปที่แผนผังย่อยด้านซ้าย B. Bนอกจากนี้ยังมีการสั่งซื้อล่วงหน้า กระบวนการดำเนินต่อไปจนกว่าจะมีการเยี่ยมชมโหนดทั้งหมด ผลลัพธ์ของการส่งผ่านคำสั่งซื้อล่วงหน้าของต้นไม้นี้จะเป็น -
A → B → D → E → C → F → G
อัลกอริทึม
Until all nodes are traversed −
Step 1 − Visit root node.
Step 2 − Recursively traverse left subtree.
Step 3 − Recursively traverse right subtree.
Post-order Traversal
ในวิธีการข้ามผ่านนี้โหนดรูทจะถูกเยี่ยมชมเป็นครั้งสุดท้ายดังนั้นชื่อ อันดับแรกเราสำรวจทรีย่อยด้านซ้ายจากนั้นทรีย่อยด้านขวาและสุดท้ายโหนดรูท
เริ่มจาก Aและหลังจากผ่านการสั่งซื้อภายหลังเราไปที่แผนผังย่อยด้านซ้ายก่อน B. Bนอกจากนี้ยังมีการส่งผ่านภายหลังการสั่งซื้อ กระบวนการดำเนินต่อไปจนกว่าจะมีการเยี่ยมชมโหนดทั้งหมด ผลลัพธ์ของการส่งผ่านหลังการสั่งซื้อของต้นไม้นี้จะเป็น -
D → E → B → F → G → C → A
อัลกอริทึม
Until all nodes are traversed −
Step 1 − Recursively traverse left subtree.
Step 2 − Recursively traverse right subtree.
Step 3 − Visit root node.
ในการตรวจสอบการดำเนินงานของ C traversing ต้นไม้โปรดคลิกที่นี่