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

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

 

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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
ฟอร์มรับเงิน Omise เราสามารถเปลี่ยน logo ได้มั้ยคะ
โดย thatsawan ศ 03 ก.ค. 2020 6:03 pm บอร์ด Programming - PHP
0
7
ศ 03 ก.ค. 2020 6:03 pm โดย thatsawan
input type="date" ไม่เเสดงเป็นปฎิทินวันที่ให้ใน safari แก้ไขยังไงคะ
โดย thatsawan พฤ 02 ก.ค. 2020 2:31 pm บอร์ด HTML CSS
0
34
พฤ 02 ก.ค. 2020 2:31 pm โดย thatsawan
การสร้าง bot messenger ของ facebook โดยใช้ pymessenger
โดย jirawoot พฤ 02 ก.ค. 2020 1:44 pm บอร์ด Python Knowledge
0
34
พฤ 02 ก.ค. 2020 1:44 pm โดย jirawoot
Q - ทดลองทำเอกสารยื่นแบบผ่านเน็ตแล้ว ไฟล์ txt ใช้ไม่ได้
โดย natthanit.r2538 พ 01 ก.ค. 2020 4:59 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
3
48
พ 01 ก.ค. 2020 5:41 pm โดย natthanit.r2538
สรุปการยื่นแบบภาษีออนไลน์
โดย natthanit.r2538 อ 30 มิ.ย. 2020 5:32 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
1
48
อ 30 มิ.ย. 2020 7:18 pm โดย natthanit.r2538
หลักการคิดค่าคอมมิชชั่น และวิธีการคิด รายได้จาก Commission
โดย natthanit.r2538 อ 30 มิ.ย. 2020 11:31 am บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
47
อ 30 มิ.ย. 2020 11:31 am โดย natthanit.r2538
MJUpgrade อัพเกรดไม่สำเร็จ Error: zip file not found
โดย chaiyaphat ศ 26 มิ.ย. 2020 11:01 am บอร์ด Joomla Development
3
500
ศ 26 มิ.ย. 2020 1:24 pm โดย mindphp
ตั้งค่าใช้ Email ใน phpbb เเล้ว ไม่ทำงาน
โดย thatsawan พฤ 25 มิ.ย. 2020 5:37 pm บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
5
93
ส 27 มิ.ย. 2020 4:43 pm โดย thatsawan
เจอปัญหาตอนทำรายการ Omise เป็นบางครั้ง Error Uncaught OmiseInvalidChargeException
โดย thatsawan พฤ 25 มิ.ย. 2020 3:56 pm บอร์ด Programming - PHP
2
67
จ 29 มิ.ย. 2020 5:29 pm โดย thatsawan
ต้องการจะสร้างไฟล์ HTML เเต่นำค่า php ไป HTML โดย Twig เขียนใน phpbb จะทำยังไงคะ
โดย thatsawan พ 24 มิ.ย. 2020 5:45 pm บอร์ด Programming - PHP
3
70
พฤ 25 มิ.ย. 2020 3:49 pm โดย Sirayu
ถ้าเราต้องการแสดงค่าตอน onchange ใน option ที่มี value มากกว่า 1
โดย thatsawan อ 23 มิ.ย. 2020 12:51 pm บอร์ด JavaScript & Jquery Ajax
2
123
อ 23 มิ.ย. 2020 3:01 pm โดย thatsawan
4 จุดเช็คอิน เกาะล้าน ยอดฮิต
โดย A2d จ 22 มิ.ย. 2020 10:44 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
2
70
ส 27 มิ.ย. 2020 12:01 am โดย A2d
ต้องการจะเปลี่ยนคำปุ่ม omise จาก Pay with Omise เป็นคำที่เรากำหนดขึ้นเอง
โดย thatsawan จ 22 มิ.ย. 2020 5:18 pm บอร์ด PHP Knowledge
2
101
จ 22 มิ.ย. 2020 5:39 pm โดย thatsawan
สาเหตุที่เด็กทารกแพ้นมวัว คุณแม่จะรับมือปัญหานี้อย่างไรดี
โดย medalezga จ 22 มิ.ย. 2020 1:58 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
60
จ 22 มิ.ย. 2020 1:58 pm โดย medalezga
ไม่เข้าใจคำสั่ง preg_replace
โดย profess79 ส 20 มิ.ย. 2020 11:56 am บอร์ด Programming - PHP
1
101
ส 20 มิ.ย. 2020 6:19 pm โดย profess79
วิธีการทำทศนิยม 3 ตำแหน่ง ด้วย python
โดย bolue ศ 19 มิ.ย. 2020 4:49 pm บอร์ด Python Knowledge
0
76
ศ 19 มิ.ย. 2020 4:49 pm โดย bolue
วิธีการ เพิ่มข้อมูล ลงฐานข้อมูล พร้อม รีเทิร์น id กลับมา ด้วยคำสั่ง sql
โดย bolue ศ 19 มิ.ย. 2020 3:25 pm บอร์ด SQL Knowledge
0
546
ศ 19 มิ.ย. 2020 3:25 pm โดย bolue
เจอปัญหา ส่งเมลผิดพลาด : Language string failed to load: from_failed บน phpmailer
โดย mindphp ศ 19 มิ.ย. 2020 3:26 am บอร์ด Programming - PHP
2
1433
ศ 19 มิ.ย. 2020 5:47 pm โดย mindphp
กฎหมายที่ใช้ควบคุมโรค โควิด-19 ฝ่าฝืนได้รับโทษอย่างไรบ้าง?
โดย Decha Thaweeumanjvaroj พฤ 18 มิ.ย. 2020 10:17 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
97
พฤ 18 มิ.ย. 2020 10:17 am โดย Decha Thaweeumanjvaroj
ไม่สามารถ start openerp-server ของ openerp 7 ได้
โดย bolue พฤ 18 มิ.ย. 2020 10:09 am บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
10
170
ศ 19 มิ.ย. 2020 12:49 pm โดย bolue