ალგორითმთა ანალიზი
ალგორითმთა ანალიზი — კომპიუტერულ მეცნიერებაში ალგორითმთა გამოთვლითი სირთულის, ანუ მათი შესრულებისთვის საჭირო დროის, მეხსიერებისა და სხვა აუცილებელი რესურსების რაოდენობის განსაზღვრა. ჩვეულებრივ, ეს გულისხმობს ფუნქციის განსაზღვრას, რომელიც აკავშირებს ალგორითმის შემავალი მონაცემების სიგრძესა და გადადგმული ნაბიჯების რაოდენობას (მისი დროით სირთულეს) ან მის მიერ გამოყენებული მეხსიერების სიდიდეს (მის სივრცით სირთულეს). ითვლება, რომ ალგორითმი ეფექტურია მაშინ, როდესაც ამ ფუნქციის მნიშვნელობები მცირეა, ან შემავალი მონაცემების ზრდასთან შედარებით, იზრდება ნელა. ერთი და იმავე სიგრძის სხვადასხვა შემავალმა მონაცემებმა შეიძლება ალგორითმის განსხვავებული ქცევა გამოიწვიოს, ამიტომ საუკეთესო, ყველაზე უარესი და საშუალო შემთხვევების აღწერილობები შესაძლოა საერთო ინტერესში შედიოდეს. როდესაც სხვაგვარად არ არის მითითებული, ალგორითმის შესრულების ამსახველი ფუნქცია, როგორც წესი, ზედა საზღვარია, რომელიც განისაზღვრება ყველაზე უარესი შემავალი მონაცემების ალგორითმისკენ.
ტერმინი „ალგორითმთა ანალიზი“ დონალდ კნუთმა დააარსა.[1] ალგორითმთა ანალიზი არის გამოთვლითი სირთულის თეორიის მნიშვნელოვანი ნაწილი, რომელიც ითვალისწინებს თეორიულ შეფასებებს ნებისმიერი ალგორითმისთვის საჭირო რესურსებისთვის, რაც ხსნის მოცემულ გამოთვლით პრობლემას. ამ შეფასებებში მოცემულია ეფექტური ალგორითმების ძიების გონივრული საშუალებები.
ალგორითმების თეორიულ ანალიზში ხშირია შეფასდეს მათი სირთულე ასიმპტომური გაგებით, ანუ შეფასდეს ფუნქციის სირთულე თვითნებურად დიდი შეყვანისთვის. ამ მიზნით გამოიყენება დიდი ო ნოტაცია, დიდი-ომეგა ნოტაცია და დიდი-თეტა ნოტაცია. მაგალითად, ორობითი ძებნის ნაბიჯების რაოდენობა პროპორციულია დალაგებული სიის გადარჩევისა, ან O (log(n))-ისა, კოლექტიურად „ლოგარითმულ დროში“. ჩვეულებრივ, ასიმპტომური შეფასებები გამოიყენება იმიტომ, რომ იგივე ალგორითმის სხვადასხვაგვარად განხორციელება შეიძლება განსხვავდებოდეს ეფექტურობაში. ამასთან ერთად, მოცემული ალგორითმის ნებისმიერი ორი „გონივრული“ განხორციელების ეფექტურობას უკავშირდება მუდმივი მრავლობითი ფაქტორი, რომელსაც ეწოდება ფარული მუდმივი .
ეფექტურობის ზუსტი (არაასიმპტომური) ზომები ზოგჯერ შეიძლება გამოითვალოს, მაგრამ ისინი ჩვეულებრივ მოითხოვენ გარკვეულ ალბათობით დაშვებებს ალგორითმის კონკრეტულ განხორციელებასთან დაკავშირებით, რასაც გამოთვლის მოდელი ეწოდება. გამოთვლის მოდელი შეიძლება განისაზღვროს აბსტრაქტული კომპიუტერის თვალსაზრისით, მაგალითად ტურინგის მანქანა, ან/და იმის მითითებით, რომ გარკვეული ოპერაციები ერთეულოვან დროში ხორციელდება. მაგალითად, თუ დალაგებულ სიას, რომელზეც ჩვენ ორობით ძებნას ვიყენებთ, აქვს n რაოდენობის ელემენტი და გვაქვს გარანტია, რომ სიაში არსებული ელემენტის მოძებნას ერთეულოვანი დრო დასჭირდება, მაშინ პასუხის მისაღებად დაგვჭირდება მაქსიმუმ log2 n + 1 დროის ერთეული.
სქოლიო
რედაქტირება- ↑ Knuth: Recent News (28 August 2016). დაარქივებულია ორიგინალიდან — 28 აგვისტო 2016. ციტირების თარიღი: 12 იანვარი 2020.