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 ฟังก์ชันที่ใช้อยู่ในรูปแบบเดียวกัน 

 

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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
Job : PHP Web Programmer (www.tmbbank.com)
โดย authapun2004 อ 01 มี.ค. 2011 12:21 pm บอร์ด MindPHP News & Feedback
0
1825
อ 01 มี.ค. 2011 12:21 pm โดย authapun2004 View Topic Job : PHP Web Programmer (www.tmbbank.com)
c# เว็บเซอร์ิวิสต้นทาง http ติดต่อกับปลายทาง https
โดย jataz2 อ 01 มี.ค. 2011 10:01 am บอร์ด Programming - C/C++ & java & Python
2
2667
อ 08 มี.ค. 2011 5:20 pm โดย jataz2 View Topic c# เว็บเซอร์ิวิสต้นทาง http ติดต่อกับปลายทาง https
รถเร็วเหนือเสียง รถเร็วกว่าเสียง เร็วกว่าเครื่องบินบางแบบ ข่าวช่อง 3
โดย imsn อ 01 มี.ค. 2011 1:19 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
1408
อ 01 มี.ค. 2011 1:19 am โดย imsn View Topic รถเร็วเหนือเสียง รถเร็วกว่าเสียง เร็วกว่าเครื่องบินบางแบบ ข่าวช่อง 3
แบบฟอร์มส่งเมล์ ส่งไปแล้วอ่านภาษาไทยไม่ได้ครับ
โดย Anonymous จ 28 ก.พ. 2011 9:08 am บอร์ด Programming - PHP
16
5645
พฤ 10 มี.ค. 2011 4:53 pm โดย touleg View Topic แบบฟอร์มส่งเมล์ ส่งไปแล้วอ่านภาษาไทยไม่ได้ครับ
รบกวนช่วยเขียนโค้ดอัพโหลดไฟล์pdfให้หน่อยค่ะ เป้น php นะคะ
โดย Anonymous จ 28 ก.พ. 2011 9:03 am บอร์ด Programming - PHP
1
2800
จ 28 ก.พ. 2011 4:27 pm โดย touleg View Topic รบกวนช่วยเขียนโค้ดอัพโหลดไฟล์pdfให้หน่อยค่ะ เป้น php นะคะ
ต้องการคนเขียน php สำหรับทำแบบฟอร์ม แจ้งการชำระเงิน และสามารถส่ง sms ได้ด้วย
โดย Anonymous จ 28 ก.พ. 2011 4:29 am บอร์ด MindPHP News & Feedback
0
1408
จ 28 ก.พ. 2011 4:29 am โดย บุคคลทั่วไป View Topic ต้องการคนเขียน php สำหรับทำแบบฟอร์ม แจ้งการชำระเงิน และสามารถส่ง sms ได้ด้วย
ขอลิ้งโหลดโปรแกรม PHP หน่อยคับ
โดย Improvise อ 27 ก.พ. 2011 10:26 pm บอร์ด Programming - PHP
5
2828
พฤ 03 มี.ค. 2011 4:59 pm โดย touleg View Topic ขอลิ้งโหลดโปรแกรม PHP หน่อยคับ
PHP CLASS ติดต่อฐานข้อมูล MySQL
โดย Anonymous อ 27 ก.พ. 2011 7:25 pm บอร์ด Free PHP Code Download script
0
4295
อ 27 ก.พ. 2011 7:25 pm โดย บุคคลทั่วไป View Topic PHP CLASS ติดต่อฐานข้อมูล MySQL