430 likes | 931 Views
درس طراحی الگوریتم ها. فصل چهارم. روش حریصانه Greedy approach. مدرس: سید محمد بیدکی. بهار 1392. روش حریصانه (Greedy). Scrooge هرگز به آینده یا گذشته نمی اندیشید. الگویتم حریصانه به شیوه scrooge عمل می کند.
E N D
درس طراحی الگوریتم ها فصل چهارم روش حریصانه Greedy approach مدرس: سید محمد بیدکی بهار 1392
روش حریصانه (Greedy) • Scrooge هرگز به آینده یا گذشته نمی اندیشید. • الگویتم حریصانه به شیوه scrooge عمل می کند. • به ترتیب عناصر داده ها را گرفته هر بار آن عنصری را که در حال حاضر طبق ملاکی معین بهترین به نظر می رسد بدون توجه به انتخاب هایی که قبلاً انجام داده یا در آینده انجام خواهد داد، برمی دارد. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
روش حریصانه • غالباً برای حل مسائل بهینهسازی به کار می رود.(مانند برنامه نویسی پویا) • برای هر مسئله ای نمی تواند پاسخ بهینه را بدست آورد. • باید اثبات کرد که پاسخ همواره بهینه است یا خیر • در روش حریصانه تقسیم به نمونه های کوچکتر صورت نمی پذیرد. • با انجام یک سری انتخاب که در هر لحظه بهترین به نظر می رسد عمل می کند. • انتخاب بهینه در هر لحظه (بهینه محلی - Local Optimum) • تصمیم درباره انتخاب یا رد یکی از داده های ورودی غیرقابل برگشت است. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
مثال (مسئله خرد کردن پول) • هدف برگرداندن باقیمانده پول با حداقل تعداد سکه ها می باشد. • حل با روش حریصانه • در آغاز هیچ سکه ای در مجموعه نداریم. • سکه با ارزش بیشتر انتخاب می شود. (روال انتخاب) • باید بررسی کنیم با افزودن این سکه به بقیه پول، جمع کل آنها از چیزی که باید باشد بیشتر می شود یا خیر.(بررسی امکان سنجی) • اگر با افزودن این سکه، بقیه پول از میزان لازم بیشتر نشود، این سکه به مجموعه اضافه می شود. • بررسی می شود که آیا تمام پول پرداخت شده است یا نه (بررسی راه حل) • اگر هنوز مقداری مانده بود مجدداً از مرحله انتخاب سکه، فرآیند تکرار می شود. • این تکرار تا زمانی انجام می شود که با سکه های موجود بقیه پول به طور کامل پرداخت گردد و یا اینکه امکان پرداخت پول با این سکه ها وجود نداشته باشد. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
مثال (مسئله خرد کردن پول) • زمانی که این الگوریتم کار نمی کند: • پرداخت 18 سنت با سکه های 1 ، 6 و 7 سنتی • حریصانه: دو سکه 7 سنتی و چهار سکه 1 سنتی • بهینه: سه تا سکه 6 سنتی • پرداخت 16 سنت با سکه های 12، 10، 5 و 1 سنتی • حریصانه: یک سکه 12 سنتی و چهار سکه 1 سنتی • بهینه: یک سکه 10 سنتی، یک سکه 5 سنتی و یک سکه 1 سنتی • این الگوریتم همواره جواب بهینه را نمی دهد. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
روش حریصانه • هر دور تکرار الگوریتم حریصانه شامل مراحل زیر است: • روال انتخاب: از بین عناصر، بهترین عنصر درنظر گرفته می شود. این انتخاب براساس یک معیار حریصانه که به طور محلی بهترین جواب را در هر لحظه انتخاب می کند شکل می گیرد. • بررسی امکان سنجی:بررسی می شود که آیا با انتخاب آن مولفه امکان رسیدن به جواب وجود دارد یا خیر • درصورت مثبت بودن پاسخ، آن مولفه را به مجموعه جواب اضافه می کنیم • در صورت منفی بودن پاسخ، آن مولفه را برای همیشه کنار می گذاریم. • بررسی جواب:با افزودن هر عنصر به مجموعه جواب، بررسی می کنیم اگر جواب مسئله حاصل شده است جواب بدست آمده بهینه فرض خواهد شد و کار تمام است. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
کوله پشتی کسری دراین مسئله امکان انتخاب کسری از هر شی وجود دارد. اگر کسر 0≤xi≤1 از شی i انتخاب شود ارزش pi xi بدست می آید. هدف: طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
کوله پشتی کسری • راه حل های حریصانه: • مرتب کردن اشیا به ترتیب بیشترین ارزش و انتخاب آنها • مرتب کردن اشیا به ترتیب کمترین وزن و انتخاب آنها • مرتب کردن اشیا به ترتیب بیشترین مقدار ارزش واحد وزن (pi /wi) و انتخاب آنها طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
مثال ظرفیت کوله پشتی 20 می باشد. جدول زیر نتیجه سه راه حل مختلف بیان شده را نشان می دهد: روش آخر – انتخاب براساس بیشترین ارزش هر واحد وزن شیئ، جواب بهینه را می دهد. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
مسئله زمان بندی (scheduling) • دو نوع مسئله زمان بندی داریم: • کمینه سازی زمان کل در سیستم برای انتظار کشیدن و سرویس دهی (زمان بودن در سیستم) • مثال: آرایشگاه • زمان بندی با مهلت معین (scheduling with deadline) طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
۱- کمینه سازی زمان کل در سیستم 5 + (5 + 10) + (5+ 10 + 4) = 39 مثال: زمان کل بودن در سیستم برای زمان بندی فوق طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
روش brute-force لیست تمام زمان بندی های ممکن زمان بندی [3,1,2] بهینه می باشد. مرتبه الگوریتم برابر با تعداد حالات جایگشت کارها می باشد که از درجه فاکتوریل است. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
روش حریصانه [3 , 1 , 2] • ملاک انتخاب کارها: • ابتدا کاری انتخاب شود که زمان سرویس دهی کمتری داشته باشد. • این انتخاب باعث می شود کارهای بعدی کمتر منتظر بمانند و در نتیجه زمان کل بودن آنها در سیستم کاهش می یابد. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
الگوریتم برای یافتن زمان بندی بهینه، کارها را بر اساس زمان سرویس دهی آنها به ترتیب صعودی مرتب می کنیم. کارها را به ترتیب زمان سرویس کمتر، انتخاب می کنیم. پیچیدگی الگوریتم: O(n lgn) میتوان با برهان خلف اثبات نمود که این روش همواره جواب بهینه را می دهد. قضیه: تنها زمان بندي كه كل زمان بودن در سيستم را كمينه مي كند، زمان بندي اي است كه در آن كارها برحسب افزايش زمان سرويس مرتب مي شوند. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
۲- زمان بندی با مهلت معین • در این حالت، اجرای هر کاری باید تا زمان مشخصی شروع شود در غیر این صورت آن کار دیگر قابل اجرا نخواهد بود. • مدت زمان انجام کارها برابر است. • مسئله: تعیین زمان بندی با سود کل بیشینه، با این فرض که هر کاری دارای سودی است و فقط وقتی قابل حصول است که آن کار در مهلت مقررش شروع شود. • مثال: (زمان سرویس برای هر کار 1 واحد است) طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
همه زمان بندی های ممکن زمان بندی [1, 2] غیر ممکن است. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
اصطلاحات • دنباله امكان پذير (feasible): دنباله اي از كارها كه در آن همه كارها بتوانند به ترتيب و در مهلت مقرر خود آغاز شوند. • مثال: دنباله [ 1 , 4 ] امكان پذير ولي [1, 4 ] امكان پذير نمي باشد. • مجموعه امكان پذير: مجموعه اي از كارها كه براي آن حداقل يك دنباله امكان پذير وجود داشته باشد. • مثال: مجموعه {1, 4} امکان پذیر ولی {2, 4} امکان پذیر نمی باشد. • دنباله بهينه: يك دنباله امكان پذير با حداكثر سود • مثال: دنباله [ 4, 1 ] دنباله بهینه است. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
بررسی امکان پذیری • فرض كنيد S مجموعه اي از كارها باشد. در اين صورت مجموعه Sامكان پذير خواهد بود اگر و فقط اگر دنباله حاصل از مرتب شدن کارهای S بر اساس مهلت هاي غير نزولي، امكان پذير باشد. • مثال آيا مجموعه { 1, 2, 4, 7 } امكان پذير مي باشد. • خیر، زيرا كار 4 در مهلتش نمي تواند زمان بندي شود. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
الگوریتم حریصانه sort the jobs in non-increasing order by profit; S = ᶲ; while (the instance is not solved){ select next job; //selection procedure if (S is feasible with this job added) //feasible check add this job to S; if (there are no more jobs) //solution check the instance is solved; } Sort the elements within S, in non-decreasing order by deadline; • باید نشان داد که الگوریتم همواره جواب بهینه را می دهد. • اثبات: با استفاده از استقرا بر روی تعداد کارها انجام می شود. (مراجعه به کتاب) طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
مثال 2 4 1 6 S = {1,2,4,6} [2, 1, 4, 6] , [2, 4, 1, 6] S = Ф S = {1} S = {1,2} ( [2, 1] امکان پذیر) {1, 2, 3} رد می شود. S = {1,2, 4} ( [2, 4, 1] امکان پذیر) {1, 2, 4, 5} رد می شود. S={1, 2, 4, 6} ( [2, 4, 1, 6] امکان پذیر) {1, 2, 4, 7} رد می شود. طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی
تکلیف (موعد تحویل ۱۳۹۲/۰۲/۰۹) طراحی الگوریتم - فصل چهارم: روش حریصانه - بیدکی • برنامه ای به زبان C++ یا C# یا Java بنویسید که الگوریتم مسئله کوله پشتی کسری را پیاده سازی نموده و خروجی مناسب تولید کند. • برنامه ای به زبان C++ یا C# یا Java بنویسید که الگوریتم مسئله زمانبندی با حداقل زمان بودن در سیستم را پیاده سازی کرده و خروجی مناسب تولید نماید. • برنامه ای به زبان C++ یا C# یا Java بنویسید که الگوریتم مسئله زمانبندی با مهلت معین را پیاده سازی کرده و خروجی مناسب تولید نماید. • لازم به ذکر است در برنامه های فوق، پارامترهای مسئله باید به نحو مناسب، به عنوان ورودی از صفحه کلید خوانده شوند. • طراحی واسط کاربر گرافیکی (GUI) اختیاریست ولی امتیاز مثبت دارد.