fbpx
วิกิพีเดีย

การจัดเรียงแบบหวี

การจัดเรียงข้อมูลแบบหวี (อังกฤษ: Comb sort) คือ การประยุกต์การจัดเรียงข้อมูลแบบ bubble sort เพื่อเพิ่มประสิทธิภาพในการทำงานได้เร็วขึ้นจะเป็นการการจัดเรียงข้อมูลเป็นคู่ใช้เปรียบเทียบโดยการหดตัวเข้าหากันเพื่อเปรียบเทียบค่าซึ่งจะมีความไวกว่า bubble sort และระยะในการหดตัวเข้าหากันเพื่อเปรียบเทียบนี้จะต้องนำจำนวนทั้งหมดของข้อมูลมาหารด้วย 1.3 ตลอดในการวนลูปจบแต่ละรอบเพื่อที่จะได้ระยะในการหดตัวเปรียบเทียบค่าใหม่ในรอบนั้น ๆ ถูกออกแบบเป็นครั้งแรกในปี คศ 1980 โดยคุณ Wlodzimierz Dobosiewicz  หลังจากนั้นได้ถูกปรับปรุงโดยคุณ Stephen lacey และ Richard Box

หลักการทำงาน

การทำงานของบับเบิ้ลจะมีประสิทธิภาพในการทำงานได้ช้าเพราะต้องมีการสลับตำแหน่งข้อมูลอยู่บ่อยครั้ง (จะเรียกข้อมูลที่มีค่าน้อยอยู่ในตำแหน่งหลังๆ ของชุดข้อมูลว่า Turtle)  ดังนั้นการจัดเรียงข้อมูลแบบ comb ใช้หลักการขจัดตัว Turtle โดยมีการกำหนด Gap ขึ้นมาแล้วทำการเปรียบเทียบค่าในช่วงของ Gap จะไม่ใช้วิธีการเปรียบเทียบค่าที่อยู่ใกล้กันเหมือนกับวิธีการจัดเรียงแบบบับเบิ้ล ขั้นตอนการทำงานการจัดเรียงแบบ comb sort มีหลักการดังนี้

• ให้ value เป็นการนับจำนวนข้อมูลทั้งหมดใน array ว่ามีกี่ตัวและเก็บค่าไว้

• ทำการหาระยะในการเปรียบเทียบค่าโดยการนำจำนวน value มาหารด้วย 1.3

• วนลูปจนกว่าค่าของ value ที่ทำการหารมาในแต่ละรอบจะเป็น 1

• ให้ count ทำการวน loop for อีกครั้งเพื่อเปรียบเทียบค่าของข้อมูลตำแหน่งที่ 0 ถึง array_len - value เพื่อไม่ให้การเทียบข้อมูลอยู่ที่ตัวสุดท้ายของการเทียบพอดีไม่หลุดออกจากข้อมูล

• เช็คว่าตำแหน่ง index ที่วนลูปแต่ละครั้งมากกว่าตำแหน่งของ index บวกกับ value ที่หารมาในรอบนั้นไหมถ้ามากกว่าจะสลับกัน ทำจนกว่าค่า value ที่หารออกมาจะเท่ากับ 1 ก็จบการทำงานได้

ขั้นตอนการทำ

1.คำนวณหาค่า Gap ระหว่างช่องที่จะเปรียบเทียบค่าโดยจะคำนวณหา Gap จาก Shink factor โดยคุณ Stephen lacey และ Richard Box แนะนำควรเป็น  1.3 มีที่มาจากสูตรดังนี้

 
สูตรการคำนวณ Comb sort

2.ทำการวนลูปเพื่อเทียบค่าและสลับตำแหน่งของข้อมูล การทำงานในส่วนนี้จะคล้ายกับการจัดเรียงแบบบับเบิ้ลแต่ส่วนที่ต่างกันก็คือตำแหน่งการเปรียบเทียบค่า    การเทียบค่าการจัดเรียงข้อมูลแบบบับเบิ้ลจะเทียบค่าตำแหน่งที่ i กับ i+1 ซึ่งวิธีการแบบ comb จะเทียบตำแหน่งที i กับ i+gap โดยจะทำการเทียบค่าและสลับตำแหน่งข้อมูลที่ต้องการตามจำนวนสมาชิกในชุดข้อมูล  หลังจากนั้นจะคำนวณค่า gap ใหม่อีกครั้งและเช็คว่าค่า gap เป็นหนึ่งหรือไม่มีการการสลับตำแหน่งข้อมูลแล้ว จึงจะยุติการทำงาน ทำให้ได้ชุดข้อมูลที่มีการเรียงลำดับเรียบร้อย

ตัวอย่างการทำงาน

- กำหนดให้

- count คือ ตำแหน่ง loop การเทียบค่าของ 0 ถึง array_len – value

- array_len คือ ความยาวทั้งหมดของ array

- value คือ ค่าที่ถูกหารด้วย 1.3

- index คือ ตำแหน่งเปรียบเทียบของ count + value ที่การวนลูปแต่ล่ะรอบ

จะยกตัวอย่างจากข้อมูลง่ายๆ โดยให้ข้อมูลมีความยาวเท่ากับ 7 โดยเริ่มต้นจะให้

รอบที่ 0

array_len = 7

value = 7

[ 9 , 18 , 15 , 20 , 0 , 3 , 7 ]

รอบที่ 1

value = 7 // 1.3 => 5

count = 0 , 1

Index  = 5 , 6

[ 9 , 18 , 15 , 20 , 0 , 3 , 7 ]

[ 3 , 18 , 15 , 20 , 0 , 9 , 7 ]

[ 3 , 7 , 15 , 20 , 0 , 9 , 18 ]

รอบที่ 2

value = 5 // 1.3 => 3

count = 0 , 1 , 2 , 3

Index =  3 , 4 , 5 , 6

[ 3 , 7 , 15 , 20 , 0 , 9 , 18 ]

[ 3 , 7 , 15 , 20 , 0 , 9 , 18 ]

[ 3 , 0 , 15 , 20 , 7 , 9 , 18 ]

[ 3 , 0 , 9 , 20 , 7 , 15 , 18 ]

[ 3 , 0 , 9 , 18 , 7 , 15 , 20 ]

รอบที่ 3

value = 3 // 1.3 => 2

count = 0 , 1 , 2 , 3 ,  4

Index = 2 , 3 , 4 , 5 , 6

[ 3 , 0 , 9 , 18 , 7 , 15 , 20 ]

[ 3 , 0 , 9 , 18 , 7 , 15 , 20 ]

[ 3 , 0 , 9 , 18 , 7 , 15 , 20 ]

[ 3 , 0 , 7 , 18 , 9 , 15 , 20 ]

[ 3 , 0 , 7 , 15 , 9 , 18 , 20 ]

[ 3 , 0 , 7 , 15 , 9 , 18 , 20 ]

รอบที่ 4

value = 2 // 1.3 => 1

count = 0 , 1 , 2 , 3 ,  4 , 5

Index = 1 , 2 , 3 , 4 , 5 ,  6

[ 3 , 0 , 7 , 15 , 9 , 18 , 20 ]

[ 0 , 3 , 7 , 15 , 9 , 18 , 20 ]

[ 0 , 3 , 7 , 15 , 9 , 18 , 20 ]

[ 0 , 3 , 7 , 15 , 9 , 18 , 20 ]

[ 0 , 3 , 7 , 9 , 15 , 18 , 20 ]

[ 0 , 3 , 7 , 9 , 15 , 18 , 20 ]

[ 0 , 3 , 7 , 9 , 15 , 18 , 20 ]

Code

ตัวอย่างการเขียนโปรแกรมด้วย ภาษาไพทอน (Python)

def CombSort(array): array_len = len(array) value = len(array) while value != 1 : value = int(value // 1.3) for count in range(0,array_len -value):  if array[count] >= array[count + value]:  array[count],array[count + value] = array[count + value], array[count] return array array = [9,18,15,20,0,3,7] print(CombSort(array)) 
Big O

จาก Code ด้านบนจะมีการทำงานวนลูปจำนวน 2 ลูปคือลูป while และ for โดยในแต่ละลูปจะมีค่า Big O ดังนี้

while value != 1 : จะได้ => O(n)

for index in range(0,array_len - value): จะได้ => O(n)

ลูป for อยู่ในลูป while จะนำมาคูณกันได้สมการคำตอบคือ

>>> O(n) * O(n) = O(n2)

Best Case

 เป็นกรณีที่จะทำงานแค่ 1 รอบหรือจำนวนของ array มีแค่ 1 ตัวทำให้ไม่ต้องเข้าลูป while จากนั้นจะ return ค่าของ array ออกมาได้เลย

Bio O จะเป็น Big O => O(1)

Worst Case

 เป็นกรณีที่ array มีจำนวนข้อมูลมากทำให้ต้องเข้าลูป while หลายครั้งจึงทำให้เวลาในการทำงานนานขึ้น ถ้าทำเสร็จแล้วให้ return ค่าออกมาและค่าที่ได้จะเรียงจากน้อยไปมากแล้ว

Big O จะเป็น Big O => O(n^2)

อ้างอิง

fadelc99. (2 สิงหาคม 2013) การจัดเรียงข้อมูลแบบคอมพ์ (Comb Sort). Retrieved 1 May 2018.

geeksforgeeks. Comb Sort. Retrieved 28 April 2018.

Alban Maxhuni. (24 ธ.ค. 2013) comb sort example. Retrieved 28 April 2018.

การจ, ดเร, ยงแบบหว, การจ, ดเร, ยงข, อม, ลแบบหว, งกฤษ, comb, sort, การประย, กต, การจ, ดเร, ยงข, อม, ลแบบ, bubble, sort, เพ, อเพ, มประส, ทธ, ภาพในการทำงานได, เร, วข, นจะเป, นการการจ, ดเร, ยงข, อม, ลเป, นค, ใช, เปร, ยบเท, ยบโดยการหดต, วเข, าหาก, นเพ, อเปร, ยบเท, . karcderiyngkhxmulaebbhwi xngkvs Comb sort khux karprayuktkarcderiyngkhxmulaebb bubble sort ephuxephimprasiththiphaphinkarthanganiderwkhuncaepnkarkarcderiyngkhxmulepnkhuichepriybethiybodykarhdtwekhahaknephuxepriybethiybkhasungcamikhwamiwkwa bubble sort aelarayainkarhdtwekhahaknephuxepriybethiybnicatxngnacanwnthnghmdkhxngkhxmulmahardwy 1 3 tlxdinkarwnlupcbaetlarxbephuxthicaidrayainkarhdtwepriybethiybkhaihminrxbnn thukxxkaebbepnkhrngaerkinpi khs 1980 odykhun Wlodzimierz Dobosiewicz hlngcaknnidthukprbprungodykhun Stephen lacey aela Richard Box enuxha 1 hlkkarthangan 2 khntxnkartha 2 1 twxyangkarthangan 2 1 1 rxbthi 0 2 1 2 rxbthi 1 2 1 3 rxbthi 2 2 1 4 rxbthi 3 2 1 5 rxbthi 4 3 Code 3 1 Big O 3 2 Best Case 3 3 Worst Case 4 xangxinghlkkarthangan aekikhkarthangankhxngbbebilcamiprasiththiphaphinkarthanganidchaephraatxngmikarslbtaaehnngkhxmulxyubxykhrng caeriykkhxmulthimikhanxyxyuintaaehnnghlng khxngchudkhxmulwa Turtle dngnnkarcderiyngkhxmulaebb comb ichhlkkarkhcdtw Turtle odymikarkahnd Gap khunmaaelwthakarepriybethiybkhainchwngkhxng Gap caimichwithikarepriybethiybkhathixyuiklknehmuxnkbwithikarcderiyngaebbbbebil khntxnkarthangankarcderiyngaebb comb sort mihlkkardngni ih value epnkarnbcanwnkhxmulthnghmdin array wamikitwaelaekbkhaiw thakarharayainkarepriybethiybkhaodykarnacanwn value mahardwy 1 3 wnlupcnkwakhakhxng value thithakarharmainaetlarxbcaepn 1 ih count thakarwn loop for xikkhrngephuxepriybethiybkhakhxngkhxmultaaehnngthi 0 thung array len value ephuximihkarethiybkhxmulxyuthitwsudthaykhxngkarethiybphxdiimhludxxkcakkhxmul echkhwataaehnng index thiwnlupaetlakhrngmakkwataaehnngkhxng index bwkkb value thiharmainrxbnnihmthamakkwacaslbkn thacnkwakha value thiharxxkmacaethakb 1 kcbkarthanganidkhntxnkartha aekikh1 khanwnhakha Gap rahwangchxngthicaepriybethiybkhaodycakhanwnha Gap cak Shink factor odykhun Stephen lacey aela Richard Box aenanakhwrepn 1 3 mithimacaksutrdngni sutrkarkhanwn Comb sort 2 thakarwnlupephuxethiybkhaaelaslbtaaehnngkhxngkhxmul karthanganinswnnicakhlaykbkarcderiyngaebbbbebilaetswnthitangknkkhuxtaaehnngkarepriybethiybkha karethiybkhakarcderiyngkhxmulaebbbbebilcaethiybkhataaehnngthi i kb i 1 sungwithikaraebb comb caethiybtaaehnngthi i kb i gap odycathakarethiybkhaaelaslbtaaehnngkhxmulthitxngkartamcanwnsmachikinchudkhxmul hlngcaknncakhanwnkha gap ihmxikkhrngaelaechkhwakha gap epnhnunghruximmikarkarslbtaaehnngkhxmulaelw cungcayutikarthangan thaihidchudkhxmulthimikareriyngladberiybrxy twxyangkarthangan aekikh kahndih count khux taaehnng loop karethiybkhakhxng 0 thung array len value array len khux khwamyawthnghmdkhxng array value khux khathithukhardwy 1 3 index khux taaehnngepriybethiybkhxng count value thikarwnlupaetlarxbcayktwxyangcakkhxmulngay odyihkhxmulmikhwamyawethakb 7 odyerimtncaih rxbthi 0 aekikh array len 7value 7 9 18 15 20 0 3 7 rxbthi 1 aekikh value 7 1 3 gt 5count 0 1Index 5 6 9 18 15 20 0 3 7 3 18 15 20 0 9 7 3 7 15 20 0 9 18 rxbthi 2 aekikh value 5 1 3 gt 3count 0 1 2 3Index 3 4 5 6 3 7 15 20 0 9 18 3 7 15 20 0 9 18 3 0 15 20 7 9 18 3 0 9 20 7 15 18 3 0 9 18 7 15 20 rxbthi 3 aekikh value 3 1 3 gt 2count 0 1 2 3 4Index 2 3 4 5 6 3 0 9 18 7 15 20 3 0 9 18 7 15 20 3 0 9 18 7 15 20 3 0 7 18 9 15 20 3 0 7 15 9 18 20 3 0 7 15 9 18 20 rxbthi 4 aekikh value 2 1 3 gt 1count 0 1 2 3 4 5Index 1 2 3 4 5 6 3 0 7 15 9 18 20 0 3 7 15 9 18 20 0 3 7 15 9 18 20 0 3 7 15 9 18 20 0 3 7 9 15 18 20 0 3 7 9 15 18 20 0 3 7 9 15 18 20 Code aekikhtwxyangkarekhiynopraekrmdwy phasaiphthxn Python def CombSort array array len len array value len array while value 1 value int value 1 3 for count in range 0 array len value if array count gt array count value array count array count value array count value array count return array array 9 18 15 20 0 3 7 print CombSort array Big O aekikh cak Code danbncamikarthanganwnlupcanwn 2 lupkhuxlup while aela for odyinaetlalupcamikha Big O dngniwhile value 1 caid gt O n for index in range 0 array len value caid gt O n lup for xyuinlup while canamakhunknidsmkarkhatxbkhux gt gt gt O n O n O n2 Best Case aekikh epnkrnithicathanganaekh 1 rxbhruxcanwnkhxng array miaekh 1 twthaihimtxngekhalup while caknnca return khakhxng array xxkmaidelyBio O caepn Big O gt O 1 Worst Case aekikh epnkrnithi array micanwnkhxmulmakthaihtxngekhalup while hlaykhrngcungthaihewlainkarthangannankhun thathaesrcaelwih return khaxxkmaaelakhathiidcaeriyngcaknxyipmakaelwBig O caepn Big O gt O n 2 xangxing aekikhfadelc99 2 singhakhm 2013 karcderiyngkhxmulaebbkhxmph Comb Sort Retrieved 1 May 2018 geeksforgeeks Comb Sort Retrieved 28 April 2018 Alban Maxhuni 24 th kh 2013 comb sort example Retrieved 28 April 2018 ekhathungcak https th wikipedia org w index php title karcderiyngaebbhwi amp oldid 7840123, wikipedia, วิกิ หนังสือ, หนังสือ, ห้องสมุด,

บทความ

, อ่าน, ดาวน์โหลด, ฟรี, ดาวน์โหลดฟรี, mp3, วิดีโอ, mp4, 3gp, jpg, jpeg, gif, png, รูปภาพ, เพลง, เพลง, หนัง, หนังสือ, เกม, เกม