تحلیل کارایی الگوریتمها
مسئلهی زیر را درنظر بگیرید:
مسئلهی یافتن زیرآرایه با مجموع بیشینه
در علوم کامپیوتر، مسئلهی یافتن زیرآرایه با مجموع بیشینه، انتخاب مجموعهای از خانههای مجاور از یک آرایهی یک بعدی است که مجموع عناصر آن بیشترین مقدار ممکن باشد. روشهای مختلفی برای این مسئله میتوان ارائه داد. بهطور نمونه 3 الگوریتم با دیدگاههای مختلف در این مطلب مورد بررسی قرار خواهد گرفت تا با تحلیل هریک از آنها، مفهموم مرتبهی زمانی و اهمیت الگوریتمهای کارا را نشان دهیم. برای مثال، آرایهی 10 عنصری A با مقادیر زیر را درنطر بگیرید:
A | A0 | A1 | A2 | A3 | A4 | A5 | A6 | A7 | A8 | A9 |
+2 | -1 | 0 | -2 | +5 | +7 | -4 | +8 | +4 | -8 |
الگوریتم باید بهعنوان خروجی، SUM (مقدار مجموع بیشینه)، i (اندیس شروع زیرآرایه) و j (اندیس پایان زیر آرایه) را به شرط 1 ≤ i ≤ j < n محاسبه کرده و چاپ کند. برای مثال بالا، زیر آرایه با مجموع بیشینه عبارت است از:
+2 | -1 | 0 | -2 | +5 | +7 | -4 | +8 | +4 | -8 |
که دارای مجموع 20 و از اندیس 4 تا اندیس 8 قرار دارد و در شکل بالا با مربعهای رنگی نشان داده شده است.
الگوریتم اول
برای تعیین اندیس شروع و اندیس پایان (زیرآرایهی جواب)، میتوان از دو متغیر بههمراه حلقهی تکرار استفاده کرده و هربار، ضمن محاسبهی مجموع عناصر بین آنها، بیشترین مقدار ممکن را نیز شناسایی کنیم. برنامهی زیر به زبان C++ این دیدگاه را پیادهسازی کرده است:
در پیادهسازی این الگوریتم از 3 حلقهی تکرار تودرتو استفاده شده است. طبق اصل ضرب، تعداد هر یک از حلقهها در همدیگر ضرب شده و تعداد کل تکرارها بهدست میآید. برای مقادیر مختلف n، تعداد کل دستورات در جدول زیر آمده است. توجه داشته باشید که برای راحتی کار، فقط تعداد اجرای پرتکرارترین دستور (خط شمارهی 12) شمارش شدهاست.
اندازهی مسئله | تعداد تکرار |
10 | 220 |
100 | 171,700 |
1000 | 167,167,000 |
10000 | 166,716,670,000 |
الگوریتم دوم
با کمی دقت در الگوریتم اول، با اندکی تغییر میتوان حلقهی سوم (داخلیترین حلقه) را حذف کرد. وظیفهی این حلقه، جمع تمامی اعداد محصور بین اندیسهای I و J است. از آنجاییکه در ابتدا مقدار J برابر I است و رفته رفته از هم دور میشوند، لذا میتوان همزمان با مرور مقادیر جدید توسط J، مجموع عناصر را نیز بدست آورد و نیازی به تشکیل حلقهی تکرار دیگری نیست. این بهبود در کد زیر پیادهسازی شده و فقط با دو حلقهی تکرار تودرتو نوشته شدهاست:
برای مقادیر مختلف n، تعداد کل دستورات در جدول زیر آمده است. مانند الگوریتم قبلی، فقط تعداد اجرای پرتکرارترین دستور (خط شمارهی 11) شمارش شدهاست.
اندازهی مسئله | تعداد تکرار |
10 | 55 |
100 | 5,050 |
1000 | 500,500 |
10000 | 50,005,000 |
با مقایسهی نتایج اجرای این الگوریتم (جدول بالا) با نتیجهی الگوریتم اول، ملاحظه میشود که بهبود بسیار خوبی حاصل شده است. الگوریتم بعدی، تنها با یک حلقهی تکرار نوشته شده است.
الگوریتم سوم
جالب است بدانید که این مسئله را میتوان با الگوریتم کارآمدتری حل کرد که در آن فقط یک حلقهی تکرار استفاده شدهاست. ایدهی حل مسئله با یک حلقهی تکرار، بر محاسبهی بیشترین مجموع تا محل هر یک از عناصر آرایه تمرکز دارد. بیشترین مجموع در کل، بهعنوان جواب نهایی مسئله انتخاب میشود. به برنامهی زیر توجه کنید:
برنامهی بالا، برای حل مسئله فقط از یک حلقهی تکرار استفاده میکند لذا تعداد اجرای دستورات برابر اندازهی مسئله است. در جدول زیر مقایسهای بین نتایج اجرای هر سه الگوریتم گفته شده در این مطلب آمده است: