ความแตกต่างระหว่าง Stack และ Heap

Anonim

Stack vs. Heap

กองซ้อนเป็นรายการสั่งที่แทรกและลบรายการที่สามารถทำได้เฉพาะในปลายด้านหนึ่งเรียกว่า ด้านบน ด้วยเหตุผลนี้สแต็คจึงถือเป็นโครงสร้างข้อมูล Last in First out (LIFO) Heap เป็นโครงสร้างข้อมูลพิเศษที่อิงกับต้นไม้และมีคุณสมบัติพิเศษที่เรียกว่า heap property นอกจากนี้กองเป็นต้นไม้ที่สมบูรณ์ซึ่งหมายความว่าไม่มีช่องว่างระหว่างใบของต้นไม้ i. อี ในต้นไม้ที่สมบูรณ์ทุกระดับจะเต็มไปก่อนที่จะเพิ่มระดับใหม่ไปยังต้นไม้และโหนดในระดับที่กำหนดจะเต็มไปจากซ้ายไปขวา

Stack คืออะไร?

ตามที่กล่าวมาก่อน stack เป็นโครงสร้างข้อมูลที่มีการเพิ่มและลบองค์ประกอบออกจากปลายด้านหนึ่งเรียกว่าด้านบน กองซ้อนอนุญาตให้ใช้งานได้สองขั้นตอนเท่านั้นคือ push และ pop การดำเนินการผลักดันจะเพิ่มองค์ประกอบใหม่ลงในส่วนบนสุดของกองซ้อน การดำเนินการแบบ pop ลบองค์ประกอบออกจากส่วนบนของ stack ถ้ากองซ้อนเต็มแล้วเมื่อดำเนินการแบบพุชจะถือว่าเป็นสแตกล้น หากมีการดำเนินการป๊อปอัพบนสแตกที่ว่างอยู่แล้วถือว่าเป็นสแต็กล้น เนื่องจากมีการดำเนินงานจำนวนน้อยที่สามารถดำเนินการได้บนกองซ้อนจึงถือเป็นโครงสร้างข้อมูลที่ จำกัด นอกจากนี้ตามวิธีการที่การดำเนินการดันและป๊อปมีการกำหนดเป็นที่ชัดเจนว่าองค์ประกอบที่ถูกเพิ่มล่าสุดในสแต็คจะออกไปจากกองก่อน ดังนั้นกองจะถือเป็นโครงสร้างข้อมูล LIFO

Heap คืออะไร?

ดังที่ได้กล่าวมาแล้ว heap เป็นโครงสร้างที่สมบูรณ์ซึ่งสามารถตอบสนองคุณสมบัติ heap ได้ Heap property ระบุว่าถ้า y เป็นโหนดย่อยของ x ค่าที่เก็บไว้ในโหนด x ควรมากกว่าหรือเท่ากับค่าที่เก็บไว้ในโหนด y (i. e. value (x) ≥ value (y)) คุณสมบัตินี้อนุมานได้ว่าโหนดที่มีค่ามากที่สุดจะถูกวางไว้ที่ราก heap ที่สร้างโดยใช้คุณสมบัตินี้เรียกว่า max-heap มีรูปแบบอื่นของคุณสมบัติฮีปที่ระบุย้อนกลับของนี้ (เช่นค่า e (x) ≤ค่า (y)) นี่หมายความว่าโหนดที่มีค่าน้อยที่สุดจะถูกวางไว้ที่รากซึ่งเรียกว่า min-heap มีการดำเนินการที่หลากหลายในกองเช่นการค้นหาค่าต่ำสุด (ใน min-heaps) หรือ maximum (ใน heaps สูงสุด) การลบค่าต่ำสุด (ใน min-heaps) หรือ maximum (ใน max-heaps) เพิ่มขึ้น (ใน max - ฮีท) หรือลดลง (ใน min-heaps) คีย์ ฯลฯ

ความแตกต่างระหว่าง Stack และ Heap คืออะไร?

ข้อแตกต่างหลักระหว่าง stacks และ heaps คือในขณะ stack เป็นโครงสร้างข้อมูลเชิงเส้น heap เป็นโครงสร้างข้อมูลที่ไม่ใช่เชิงเส้น Stack เป็นรายการสั่งที่ทำตามไลบรารี LIFO ในขณะที่ heap เป็นโครงสร้างที่สมบูรณ์ตามคุณสมบัติ heapนอกจากนี้สแต็คเป็นโครงสร้างข้อมูลที่ จำกัด ซึ่งสนับสนุนเฉพาะการดำเนินการที่ จำกัด ในรูปแบบ push และ pop เท่านั้นในขณะที่ฮีปสนับสนุนการดำเนินการที่หลากหลายเช่นการค้นหาและลบค่าต่ำสุดหรือสูงสุดเพิ่มหรือลดคีย์และการรวม