Python - กอง

ฮีปเป็นโครงสร้างต้นไม้พิเศษที่แต่ละโหนดแม่มีค่าน้อยกว่าหรือเท่ากับโหนดลูก จากนั้นจะเรียกว่า Min Heap หากโหนดแม่แต่ละโหนดมีค่ามากกว่าหรือเท่ากับโหนดลูกจะเรียกว่าฮีปสูงสุด มีประโยชน์มากคือการใช้ลำดับความสำคัญในกรณีที่รายการคิวที่มีน้ำหนักมากกว่าจะได้รับลำดับความสำคัญในการประมวลผลมากกว่า การอภิปรายโดยละเอียดเกี่ยวกับฮีปมีอยู่ในเว็บไซต์ของเราที่นี่ โปรดศึกษาก่อนหากคุณยังใหม่กับโครงสร้างข้อมูลส่วนหัว ในบทนี้เราจะเห็นการใช้โครงสร้างข้อมูลฮีปโดยใช้ python

สร้างฮีป

ฮีปถูกสร้างขึ้นโดยใช้ไลบรารี inbuilt ของ python ชื่อ heapq ไลบรารีนี้มีฟังก์ชันที่เกี่ยวข้องเพื่อดำเนินการต่างๆในโครงสร้างข้อมูลฮีป ด้านล่างนี้คือรายการของฟังก์ชันเหล่านี้

  • heapify - ฟังก์ชันนี้จะแปลงรายการปกติเป็นฮีป ในฮีปผลลัพธ์องค์ประกอบที่เล็กที่สุดจะถูกผลักไปที่ตำแหน่งดัชนี 0 แต่องค์ประกอบข้อมูลที่เหลือไม่จำเป็นต้องเรียงลำดับ
  • heappush - ฟังก์ชั่นนี้เพิ่มองค์ประกอบให้กับฮีปโดยไม่ต้องแก้ไขฮีปปัจจุบัน
  • heappop - ฟังก์ชันนี้ส่งคืนองค์ประกอบข้อมูลที่เล็กที่สุดจากฮีป
  • heapreplace - ฟังก์ชันนี้จะแทนที่องค์ประกอบข้อมูลที่เล็กที่สุดด้วยค่าใหม่ที่ให้มาในฟังก์ชัน

การสร้าง Heap

ฮีปถูกสร้างขึ้นโดยใช้รายการองค์ประกอบที่มีฟังก์ชันฮีพ ในตัวอย่างด้านล่างเราจัดเตรียมรายการองค์ประกอบและฟังก์ชันฮีปไฟฟายจะจัดเรียงองค์ประกอบใหม่โดยนำองค์ประกอบที่เล็กที่สุดไปยังตำแหน่งแรก

import heapq

H = [21,1,45,78,3,5]
# Use heapify to rearrange the elements
heapq.heapify(H)
print(H)

เมื่อดำเนินการโค้ดด้านบนจะให้ผลลัพธ์ดังนี้ -

[1, 3, 5, 78, 21, 45]

การใส่เข้าไปในฮีป

การแทรกองค์ประกอบข้อมูลลงในฮีปจะเพิ่มองค์ประกอบที่ดัชนีสุดท้ายเสมอ แต่คุณสามารถใช้ฟังก์ชัน heapify อีกครั้งเพื่อนำองค์ประกอบที่เพิ่มเข้ามาใหม่ในดัชนีแรกได้ก็ต่อเมื่อมีค่าน้อยที่สุดเท่านั้น ในตัวอย่างด้านล่างเราใส่หมายเลข 8

import heapq
H = [21,1,45,78,3,5]
# Covert to a heap
heapq.heapify(H)
print(H)
# Add element
heapq.heappush(H,8)
print(H)

เมื่อดำเนินการโค้ดด้านบนจะให้ผลลัพธ์ดังนี้ -

[1, 3, 5, 78, 21, 45]
[1, 3, 5, 78, 21, 45, 8]

การลบออกจากฮีป

คุณสามารถลบองค์ประกอบที่ดัชนีแรกได้โดยใช้ฟังก์ชันนี้ ในตัวอย่างด้านล่างฟังก์ชันจะลบองค์ประกอบที่ตำแหน่งดัชนี 1 เสมอ

import heapq

H = [21,1,45,78,3,5]
# Create the heap

heapq.heapify(H)
print(H)

# Remove element from the heap
heapq.heappop(H)

print(H)

เมื่อดำเนินการโค้ดด้านบนจะให้ผลลัพธ์ดังนี้ -

[1, 3, 5, 78, 21, 45]
[3, 21, 5, 78, 45]

การแทนที่ใน Heap

ฟังก์ชัน heapreplace จะลบองค์ประกอบที่เล็กที่สุดของฮีปเสมอและแทรกองค์ประกอบขาเข้าใหม่ในบางตำแหน่งที่ไม่ได้รับการแก้ไขตามลำดับใด ๆ

import heapq

H = [21,1,45,78,3,5]
# Create the heap

heapq.heapify(H)
print(H)

# Replace an element
heapq.heapreplace(H,6)
print(H)
[1, 3, 5, 78, 21, 45]
[3, 6, 5, 78, 21, 45]