حل مسائل به روش حریصانه:

با روش حریصانه مسائلی را می‌توان حل کرد که در آن‌ها تعداد n n ورودی وجود دارد و می‌خواهیم با بعضی محدودیت‌های خاص زیر مجموعه‌ای از این ورودی‌ها را انتخاب کنیم.

هر زیرمجموعه‌ای که شرایط و محدودیت‌های مشخص شده را دارا باشد یک جواب ممکن به شمار می‌رود. جواب‌ها باید طوری انتخاب شوند که بین جواب‌های موجود بیشترین ارزش را داشته باشند. به این جواب‌ها، جواب بهینه می‌گویند.

حل مسئله کوله پشتی کسری به روش حریصانه:

در این مسئله n n شیئ داریم که هدف پر کردن کوله پشتی با این اشیا می‌باشد بطوری که ارزش کوله پشتی ماکزیمم شود و وزن آن از محدودیت مشخص شده‌ای تجاوز نکند.

اگر 1in 1 \le i \le n باشد یعنی شیئ i i ام بین 1 1 تا n n و 0xi1 0 \le x_i \le 1 که xi x_i میزان یا مقدار انتخابی شیئ i i ام می‌باشد به شرطی که مجموع ارزش‌ها یا i=1npixi \sum_{i=1}^{n}{p_i}{x_i} بیشینه شود و مجموع وزن‌ها کمتر مساوی وزن مشخص شده باشد یعنی i=1nwixiM \sum_{i=1}^{n}{w_i}{x_i} \le M که M M حداکثر وزن مجاز برای کوله پشتی می‌باشد.

نکته: مرتبه زمانی الگوریتم کوله پشتی کسری O(nlogn) O(n\log {n}) می‌باشد.

حل مسئله کدگذاری هافمن به روش حریصانه:

در این روش لیست کاراکترها را با توجه به فراوانی هر کاراکتر به صورت صعودی مرتب می‌کنیم سپس در هر مرحله درخت آن را رسم می‌کنیم. هدف این الگوریتم کاهش حجم فایل‌ها می‌باشد.

گراف:

هر گراف از تعدادی رأس تشکیل شده است و هر کدام از این رأس ها یا گره‌ها توسط یال‌ها به هم متصل می‌باشند. هدف اصلی مسئله پیدا کردن درخت پوشای مینیمال در یک گراف با استفاده از روش حریصانه می‌باشد.

الگوریتم راشال یا کراسکال:

در این روش در هر مرحله یال‌ها از لیست انتخاب می‌شوند و به درخت اضافه می‌شوند (یال‌ها به صورت صعودی مرتب شده و در لیست قرار گرفته‌اند) هر یال قبل از انتخاب بررسی می‌شود که در درخت پوشا دور ایجاد نکند.

نکته: در هر مرحله یک جنگل ایجاد می شود.

الگوریتم پریم:

در الگوریتم پریم در هر مرحله یک درخت داریم و هر بار نزدیک ترین همسایه انتخاب می‌شود طوری که دور ایجاد نکند.

نکات:

  • مرتبه زمانی الگوریتم پریم O(n2) O(n^2) است.
  • مرتبه زمانی الگوریتم راشال برای گراف خلوت (با تعداد یال‌های کم) برابر O(nlog2n) O(n\log_{2} n) و برای گراف‌های شلوغ O(n2log2n) O(n^2\log_{2} n) می‌باشد.
  • برای گراف‌های شلوغ از الگوریتم پریم و برای گراف‌های خلوت از الگوریتم راشال استفاده می‌کنیم.

results matching ""

    No results matching ""