ดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งาน
 

การค้นหาแบบแฮช (Hashing search) 

กระบวนการค้นหาแบบ Hashing search

 

การค้นหาแบบแฮช เป็นวิธีการค้นหาข้อมูลโดยที่ใช้การแปลงคีย์ (Key) ให้เป็นตำเเหน่ง (Address) ที่อยู่ในพื้นที่เก็บข้อมูล โดยใช้เทคนิคการสร้างตารางมาเพื่อเก็บคีย์ดังกล่าว ในการเเปลงคีย์ให้เป็นแอดเดรส คือการแปลงข้อมูลให้อยู่ในตารางแอดเดรสที่เตรียมไว้ซึ่งตารางนี้เรียกว่า ตารางแฮช (Hash Table)

 

หลักการของ Hashing search 

  • เป็นวิธีการค้นหาข้อมูลที่ใช้การแปลงคีย์ (Key) ให้เป็นตำแหน่ง (Address) ที่อยู่ในพื้นที่เก็บข้อมูล โดยใช้เทคนิคการสร้างตารางมาเพื่อเก็บคีย์ดังกล่าว

  • การแปลงคีย์ให้เป็นแอดเดรส คือการแปลงข้อมูลให้ไปอยู่ในตารางแอดเดรสที่เตรียมไว้ซึ่งเรียตารางนี้ว่า ตารางแฮช (Hash Table
  • การแปลงค่านี้ต้องอาศัยฟังก์ชัน H(k) เป็นตัวช่วยในการหาแอดเรดสของค่าคีย์ k (ค่า H(k) คือแอดเรดสของคีย์ k นั้นเอง)
  • การค้นหาด้วยวิธีนี้จะไม่ขึ้นอยู่กับจำนวนข้อมูล
  • อาศัยหลักการคำนวณตำเเหน่งที่เก็บข้อมูลจากคีย์ที่กำหนด นั้นคือจะต้องหา Hashing Function ที่เหมาะสม

 

Hashing function อย่างง่าย

hash(key) = key MOD TableSize 

TableSize คือ ขนาดของตารางที่จัดเก็บ ควรเลือกค่าที่เป็นจำนวนเฉพาะ (Prime Numbers

 

ชุดตัวเลข 9,17,22,14,13,5 กำหนดแฮชชิ่งฟังก์ชันด้วยสมการ H(K) = K MOD 9

ค่าที่ได้จากแฮชชิ่งฟังก์ชันแสดงได้ดังนี้ 

H(9) = 8                           H(17) = 8                                 H(22) = 4

H(14) = 5                           H(13) = 4                                 H(8) = 8

 

คีย์ 17 ได้ตำเเหน่ง แอดเดรสตรงกับคีย์ 8 

คีย์ 22 ได้ตำเเหน่ง แอดเดรสตรงกับคีย์ 13

การแก้ปัญหาการชนกันของคีย์ (Collision) ทำโดยการเก็บคีย์ใน Hash table แบบ 

 

สรุป การค้นหาแบบแฮช จะเป็นวิธีการค้นหาข้อมูลที่ใช้การแปลงคีย์ (key) ให้เป็นตำแหน่ง(Address) ที่อยู่ในพื้นที่เก็บข้อมูล โดยใช้เทคนิคการสร้างตารางมาเพื่อเก็บคีย์ดังกล่าวการแปลงค่านี้ต้องอาศัยฟังชัน H(k) เป็นตัวช่วยในการหาแอดเดรสของค่าคีย์ k (ค่า H(k) คือ แอดเดรสของคีย์ K นั้นเอง)

 

ช่องทางการศึกษาเพิ่มเติมข่าวสารที่น่าสนใจเกี่ยวกับ : บทความทั่วไป