ให้เรตสมาชิก: 5 / 5

ดาวใช้งานดาวใช้งานดาวใช้งานดาวใช้งานดาวใช้งาน
 

Open addressing คืออะไร ?

กระบวนการทำงานของ Open Addressing

 

Open addressing คือ การแก้ไขปัญหาการชนกันของฟังก์ชันแฮชตรงกัน ทำให้เกิดการเก็บที่เดียวกันเมื่อเกิดการชนเกิดขึ้นวิธีการของ Open addressing คือการหาช่องในตารางแฮชใหม่โดยกระโดดไปจากที่เดิมเป็นฟังก์ชันหนึ่ง จนกว่าจะหาช่องว่างเจอจึงจะใส่ค่าลงไป 

 

Open Addressing วิธีนี้เราจะค้นหาค่าตำเเหน่งถัดไปที่ช่องว่าง แล้วนำข้อมูลที่ได้มาในภายหลังไปเก็บไว้

แบ่งออกเป็น 3 ประเภท

  • Open addressing with Linear Probing
  • Open addressing with Quadratic Probing
  • Open addressing with Double Hashing

 

Linear Probing

เป็นการประยุกต์ฟังก์ชันเชิงเส้นในการหาตำเเหน่งใหม่ เช่นการเลือก F(i) = i เป็นการเสาะหาตำเเหน่งถัดจากที่เกิด Collision เพื่อใช้เป็นที่เก็บข้อมูลหากตำแหน่งถัดไปถูกจับจองโดยข้อมูลที่มีอยู่ก่อน ก็จะขยับไปตำเเหน่งถัดไปอีก 1 หนึ่งช่อง (ในลักษณะการขยับไปเรื่อย ๆ แบบเชิงเส้น) เช่นนี้เรื่อยไปจนกว่าจะเจอตำเเหน่งว่าง จึงจะเก็บข้อมูลลงในช่องดังกล่าว จะเห็นว่าวิธีการนี้ล่าช้าทั้งในระหว่างการสืบค้น เพื่อเพิ่มข้อมูล

 

Quadratic Probing

เพื่อแก้ปัญหาความล่าช้าของวิธี Linear Probing จึงมีการเลือก Collision resolution function เพื่อลดความล่าช้าในการหาตำเเหน่งใหม่หลังจากที่เกิด Collision ฟังก์ชันที่ใช้อยู่ในรูปแบบเดียวกันกับ Linear Probing

 

Double Hashing

เป็นความพยายามแก้ปัญหาของ Linear Probing และ Quadratic Probing ที่เสาะหาในตำเเหน่งที่ซ้ำ ๆ อันเป็นสาเหตุของการชนครั้งเเล้วครั้งเล่า โดยอาศัย randomness ของ hash function ในการหาตำเเหน่งใหม่หลังจากการชนกันขึ้น Collision resolution function

 

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

 

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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
Private Messaging ระบบส่งข้อความส่วนตัวยอดฮิต
โดย PhoorichayaM พฤ 08 ต.ค. 2020 12:06 pm บอร์ด Share Knowledge
0
126
พฤ 08 ต.ค. 2020 12:06 pm โดย PhoorichayaM
วิธีดูข้อมูลย้อนหลัง และ กู้ข้อมูลมาใช้ใน Google Sheets ประวัติการทำงานในไฟล์เอกสาร
โดย nalinthip พฤ 08 ต.ค. 2020 11:57 am บอร์ด Google For Work Knowledge
0
150
พฤ 08 ต.ค. 2020 11:57 am โดย nalinthip
สอบถามการขึ้น column ใหม่ ให้ เมนู ใน joomla ค่ะ
โดย bolue พฤ 08 ต.ค. 2020 11:44 am บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
1
125
ศ 09 ต.ค. 2020 1:06 pm โดย mindphp
วิธีการแชร์งานให้คนอื่นได้ดูและแก้ไขใน Google Sheets
โดย nalinthip พฤ 08 ต.ค. 2020 11:29 am บอร์ด Google For Work Knowledge
0
165
พฤ 08 ต.ค. 2020 11:29 am โดย nalinthip
E Registration อีกหนึ่งบริการที่น่าสนใจ
โดย PhoorichayaM พฤ 08 ต.ค. 2020 11:12 am บอร์ด Share Knowledge
0
145
พฤ 08 ต.ค. 2020 11:12 am โดย PhoorichayaM
วิธีการคำนวณ FIBONACCI SERIES PHP
โดย makup พฤ 08 ต.ค. 2020 8:47 am บอร์ด PHP Knowledge
0
72
พฤ 08 ต.ค. 2020 8:47 am โดย makup
เจอ Error ในการใช้คำสั่ง composer global remove laravel/installer ใน Command Terminal
โดย makup พ 07 ต.ค. 2020 8:07 pm บอร์ด Programming - PHP
2
248
จ 12 ต.ค. 2020 10:31 pm โดย makup
วิธีการคำนวณ Sum of individual digits of a number PHP
โดย makup พ 07 ต.ค. 2020 6:54 pm บอร์ด PHP Knowledge
0
78
พ 07 ต.ค. 2020 6:54 pm โดย makup