โครงสร้างข้อมูลและอัลกอริทึม - 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 ต้นไม้โปรดคลิกที่นี่