Quadratic probing  หมายถึงอะไร ? 

กระบวนการค้นหาแบบ Quadratic probing

 

Quadratic probing คือวิธีแก้ปัญหาความล่าช้าของวิธี linear probing จึงมีการเลือก Collision Resolution Function เพื่อลดความล่าช้าในการหาตำเเหน่งใหม่หลังจากเกิด Collision ฟังก์ชันที่ใช้ก็อยู่ในรูปแบบเดียวกับ linear probing ก็คือ F(i) = i2 โดยที่ i แทนครั้งที่หา (Probe)

การหาตำเเหน่งใหม่ครั้งเเรก สามารถคำนวณจาก 

ตำเเหน่งใหม่ (1) = h(31) + 12 = 31% 11+1  = 10%11 = 10 

 

หากมีการชนกันอัก ก็จะหาตำเเหน่งใหม่ (ครั้งที่ 2 และ 3) จาก

 

ตำเเหน่งใหม่ (2) = h(31) + 22 = 31% 11+4  = 13%11 = 2

ตำเเหน่งใหม่ (3) = h(31) + 32 = 31% 11+9  = 10%11 = 7

 

โดยจะทำเช่นนี้เรื่อย ๆ จนกว่าจะเจอตำเเหน่งว่างที่สามารถบรรจุข้อมูลลงไป จะเห็นว่า วิธีนี้สามารถใช้หลักกระโดดทีละหลาย ๆ ตำเเหน่ง โดยจะเริ่มจาก 1,4,9 เป็นต้นไปเเล้วหวังว่าจะไม่เกิดการชนเช่น วิธี linear probing ซึ่งจะขยับทีละตำเเหน่ง ทำให้มีโอกาสเกิด การชนกันกับข้อมูลอื่นสูง แต่ในทางปฏิบัติกลับไม่เกิดผลดีเท่าที่ควร เนื่องจากการกระโดดจะทำให้เกิดการข้ามตำเเหน่งในระยะคงที่เสมอ คือ 1,4,9 ตำเเหน่งเช่นนี้เรื่อย ๆ ไป 

 

ในการ Implement จริง ฟังก์ชัน F(i) จะทำงานล่าช้า จึงมีการหาวิธีลัดเพื่อให้เพิ่มประสิทธิภาพของการคำนวณ hash function ที่รวดเร็วและสิ้นเปลืองน้อยที่สุด โดยจะเห็นว่าจากวิธีข้างต้นนั้น ค่าของ collision resolution function หรือ F(i) ที่คำนวณมาได้คือ 1,4,9,16 และ 25 วิธีลัดก็อการเลี่ยงการยกกำลัง แต่จะอาศัยการคูณ และการบวก จากความสัมพันธ์ 

 

F(i) = F(i-1) + 2*i - 1 

โดย F(0) เมื่อแทนค่าในสมการความสัมพันธ์แล้ว

F(1) = F(0) + 2*1 - 1 = 1 

F(2) = F(1) + 2*2 - 1 =4

F(3) = F(2) + 2*3 - 1 = 9 

 

ซึ่งการคูณจำนวนใด ๆ ด้วยสองในระดับฮาร์ดแวร์คือการ shift  bit ของจำนวนที่ต้องการคูณสองไปทางซ้าย 1 ครั้ง ทำให้การคูณค่าของ F(i) สามารถกระทำได้อย่างรวดเร็ว เพราะ operations ที่ใช้คือค่าเก่าเพียงค่าเก่าของ F(i) (คือ F(i)) การ shift bit และการลบหนึ่ง เท่านั้น 

 

สรุป Quadratic probing เป็นวิธีที่ 2 ของ Open addressing ซึ่งถูกออกแบบมาในการแก้ปัญหาความล่าช้าของ linear probing โดยจะเลือกใช้ Collision Resolution Function เพื่อลดความล่าช้าในการหาตำแหน่งใหม่หลังจากที่เกิด Collision ฟังก์ชันที่ใช้อยู่ในรูปแบบเดียวกัน 

 

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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
แจ้งปัญหาโพสบทความลงในเว็บบอร์ดส่วนตัวไม่ได้
โดย internTk21 ศ 19 เม.ย. 2024 11:56 am บอร์ด MindPHP News & Feedback
1
5
ศ 19 เม.ย. 2024 12:15 pm โดย internTk21 View Topic แจ้งปัญหาโพสบทความลงในเว็บบอร์ดส่วนตัวไม่ได้
สอบถาม Google Structure ที่เหมาะกับคอร์สเรียนควรใช้แบบไหนดีค่ะ
โดย eange08 ศ 19 เม.ย. 2024 9:56 am บอร์ด Programming - PHP
1
10
ศ 19 เม.ย. 2024 10:28 am โดย mindphp View Topic สอบถาม Google Structure ที่เหมาะกับคอร์สเรียนควรใช้แบบไหนดีค่ะ
คำสั่งรวมไฟล์ และ บีบอัดในคำสั่งเดียว tar, zip
โดย mindphp พ 17 เม.ย. 2024 7:42 pm บอร์ด Linux - Web Server
0
41
พ 17 เม.ย. 2024 7:42 pm โดย mindphp View Topic คำสั่งรวมไฟล์ และ บีบอัดในคำสั่งเดียว  tar, zip
เช็คขนาดพื้นที่ฐานข้อมูล แต่ละก้อน แต่ละฐานข้อมูลว่าใช้พื้นที่ไปเท่าไหร่ ด้วย Comamnd Line
โดย mindphp จ 15 เม.ย. 2024 11:10 pm บอร์ด PostgreSQL
1
163
จ 15 เม.ย. 2024 11:14 pm โดย mindphp View Topic เช็คขนาดพื้นที่ฐานข้อมูล แต่ละก้อน แต่ละฐานข้อมูลว่าใช้พื้นที่ไปเท่าไหร่ ด้วย Comamnd Line
การติดตั้ง WSL เพื่อใช้งาน Linux Terminal บน Windows
โดย tsukasaz ศ 12 เม.ย. 2024 2:25 pm บอร์ด Share Knowledge
0
185
ศ 12 เม.ย. 2024 2:25 pm โดย tsukasaz View Topic การติดตั้ง WSL เพื่อใช้งาน Linux Terminal บน Windows
Super Сasual Dating - Real Women
โดย heroxbay ศ 12 เม.ย. 2024 8:55 am บอร์ด Microsoft Office Knowledge & line & Etc
0
140
ศ 12 เม.ย. 2024 8:55 am โดย heroxbay View Topic Super Сasual Dating - Real Women
Unsurpassed Сasual Dating - True Females
โดย pongsu1968 ศ 12 เม.ย. 2024 5:47 am บอร์ด Microsoft Office Knowledge & line & Etc
0
160
ศ 12 เม.ย. 2024 5:47 am โดย pongsu1968 View Topic Unsurpassed Сasual Dating - True Females
Question Tag ใช้อย่างไรในภาษาอังกฤษ
โดย internTk21 พฤ 11 เม.ย. 2024 10:46 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
83
พฤ 11 เม.ย. 2024 10:46 pm โดย internTk21 View Topic Question Tag ใช้อย่างไรในภาษาอังกฤษ