۰
subtitle
ارسال: #۱
  
پیدا کردن با ارزش ترین مسیر در یک ماتریس
سلام من یک سوالی دیدم و نمیدونم به کدووم بحث طراحی الگوریتم مربوط میشه!! احساس میکنم این مسئله جزو مسئله های مهم و کاربردی طراحی الگوریتم
فرض میکنیم یک ماتریسی داریم در ابعاد N*M که تو هر کدوم از خانه های این ماتریس به تعداد [tex]C_{i.j}[/tex] سکه وجود داره!!
حالا عامل هوشمندی رو وارد ماتریس میکنیم که از محل یک و یک شروع به حرکت میکنه تا به محل N*M برسه
این عامل هوشمند فقط میتونه در دو جهت حرکت کنه(یک خانه به سمت راست یا یک خانه به سمت پایین)
الگوریتمی پیدا کنید که این عامل هوشمند در مسیری حرکت کند که حاوی بیشترین تعداد سکه باشد
فرض میکنیم یک ماتریسی داریم در ابعاد N*M که تو هر کدوم از خانه های این ماتریس به تعداد [tex]C_{i.j}[/tex] سکه وجود داره!!
حالا عامل هوشمندی رو وارد ماتریس میکنیم که از محل یک و یک شروع به حرکت میکنه تا به محل N*M برسه
این عامل هوشمند فقط میتونه در دو جهت حرکت کنه(یک خانه به سمت راست یا یک خانه به سمت پایین)
الگوریتمی پیدا کنید که این عامل هوشمند در مسیری حرکت کند که حاوی بیشترین تعداد سکه باشد
۱
ارسال: #۲
  
RE: پیدا کردن با ارزش ترین مسیر در یک ماتریس
(۱۶ خرداد ۱۳۹۵ ۰۸:۲۱ ب.ظ)kamal3401 نوشته شده توسط: سلام من یک سوالی دیدم و نمیدونم به کدووم بحث طراحی الگوریتم مربوط میشه!! احساس میکنم این مسئله جزو مسئله های مهم و کاربردی طراحی الگوریتم
فرض میکنیم یک ماتریسی داریم در ابعاد N*M که تو هر کدوم از خانه های این ماتریس به تعداد [tex]C_{i.j}[/tex] سکه وجود داره!!
حالا عامل هوشمندی رو وارد ماتریس میکنیم که از محل یک و یک شروع به حرکت میکنه تا به محل N*M برسه
این عامل هوشمند فقط میتونه در دو جهت حرکت کنه(یک خانه به سمت راست یا یک خانه به سمت پایین)
الگوریتمی پیدا کنید که این عامل هوشمند در مسیری حرکت کند که حاوی بیشترین تعداد سکه باشد
این مسأله با dynamic programming حل میشه.
به صورت بازگشتی باید تابع cost رو اجرا کنید:
[tex]cost(i,j)=C_{i, j}+\max\{cost(i+1, j),\: cost(i, j+1)\}[/tex]
ارسال: #۳
  
RE: پیدا کردن با ارزش ترین مسیر در یک ماتریس
(۱۶ خرداد ۱۳۹۵ ۰۸:۵۶ ب.ظ)behnam5670 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۸:۲۱ ب.ظ)kamal3401 نوشته شده توسط: سلام من یک سوالی دیدم و نمیدونم به کدووم بحث طراحی الگوریتم مربوط میشه!! احساس میکنم این مسئله جزو مسئله های مهم و کاربردی طراحی الگوریتم
فرض میکنیم یک ماتریسی داریم در ابعاد N*M که تو هر کدوم از خانه های این ماتریس به تعداد [tex]C_{i.j}[/tex] سکه وجود داره!!
حالا عامل هوشمندی رو وارد ماتریس میکنیم که از محل یک و یک شروع به حرکت میکنه تا به محل N*M برسه
این عامل هوشمند فقط میتونه در دو جهت حرکت کنه(یک خانه به سمت راست یا یک خانه به سمت پایین)
الگوریتمی پیدا کنید که این عامل هوشمند در مسیری حرکت کند که حاوی بیشترین تعداد سکه باشد
این مسأله با dynamic programming حل میشه.
به صورت بازگشتی باید تابع cost رو اجرا کنید:
[tex]cost(i,j)=C_{i, j}+\max\{cost(i+1, j),\: cost(i, j+1)\}[/tex]
فکر نکنم این الگوریتم درست باشه
ممکنه در جهت راست که حرکت میکنه تعداد سکه کمتری نسبت به جهت پایین باشه ولی تو ادامه مسیر تعداد سکه های اون قسمت بیشتر باشه
ارسال: #۴
  
RE: پیدا کردن با ارزش ترین مسیر در یک ماتریس
(۱۶ خرداد ۱۳۹۵ ۰۹:۱۱ ب.ظ)kamal3401 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۸:۵۶ ب.ظ)behnam5670 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۸:۲۱ ب.ظ)kamal3401 نوشته شده توسط: سلام من یک سوالی دیدم و نمیدونم به کدووم بحث طراحی الگوریتم مربوط میشه!! احساس میکنم این مسئله جزو مسئله های مهم و کاربردی طراحی الگوریتم
فرض میکنیم یک ماتریسی داریم در ابعاد N*M که تو هر کدوم از خانه های این ماتریس به تعداد [tex]C_{i.j}[/tex] سکه وجود داره!!
حالا عامل هوشمندی رو وارد ماتریس میکنیم که از محل یک و یک شروع به حرکت میکنه تا به محل N*M برسه
این عامل هوشمند فقط میتونه در دو جهت حرکت کنه(یک خانه به سمت راست یا یک خانه به سمت پایین)
الگوریتمی پیدا کنید که این عامل هوشمند در مسیری حرکت کند که حاوی بیشترین تعداد سکه باشد
این مسأله با dynamic programming حل میشه.
به صورت بازگشتی باید تابع cost رو اجرا کنید:
[tex]cost(i,j)=C_{i, j}+\max\{cost(i+1, j),\: cost(i, j+1)\}[/tex]
فکر نکنم این الگوریتم درست باشه
ممکنه در جهت راست که حرکت میکنه تعداد سکه کمتری نسبت به جهت پایین باشه ولی تو ادامه مسیر تعداد سکه های اون قسمت بیشتر باشه
یا جواب رو با دقت نخوندید یا dynamic programming رو بلد نیستید.
در فرمول ننوشتم که [tex]cost(i,\: j)=C_{i,\: j}+\max\{C_{i+1,\: j},\: C_{i,\: j+1}\}[/tex]
نوشتم [tex]cost(i,j)=C_{i, j}+\max\{cost(i+1, j),\: cost(i, j+1)\}[/tex]. وقتی به صورت بازگشتی اجرا میشه، خود اون تابعهای cost این مشکلی که شما گفتید رو حل میکنند، چون تا آخرش اون مسیر رو به صورت انشعابی ادامه میدهند!
روی یک ماتریس ۳ در ۳ امتحان کنید. تابع [tex]cost(0,0)[/tex] به تابعهای [tex]cost(0,1)[/tex] و [tex]cost(1,0)[/tex] منشعب میشه که تابع [tex]cost(0,1)[/tex] خودش به [tex]cost(1,1)[/tex] و [tex]cost(0,2)[/tex] تبدیل میشه (همچنین تابع منشعب دوم، یعنی [tex]cost(1,0)[/tex] هم خودش دو تا میشه و هر کدوم دنبال ماکزیمم میگردند...)
ارسال: #۵
  
RE: پیدا کردن با ارزش ترین مسیر در یک ماتریس
(۱۶ خرداد ۱۳۹۵ ۰۹:۲۰ ب.ظ)behnam5670 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۹:۱۱ ب.ظ)kamal3401 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۸:۵۶ ب.ظ)behnam5670 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۸:۲۱ ب.ظ)kamal3401 نوشته شده توسط: سلام من یک سوالی دیدم و نمیدونم به کدووم بحث طراحی الگوریتم مربوط میشه!! احساس میکنم این مسئله جزو مسئله های مهم و کاربردی طراحی الگوریتم
فرض میکنیم یک ماتریسی داریم در ابعاد N*M که تو هر کدوم از خانه های این ماتریس به تعداد [tex]C_{i.j}[/tex] سکه وجود داره!!
حالا عامل هوشمندی رو وارد ماتریس میکنیم که از محل یک و یک شروع به حرکت میکنه تا به محل N*M برسه
این عامل هوشمند فقط میتونه در دو جهت حرکت کنه(یک خانه به سمت راست یا یک خانه به سمت پایین)
الگوریتمی پیدا کنید که این عامل هوشمند در مسیری حرکت کند که حاوی بیشترین تعداد سکه باشد
این مسأله با dynamic programming حل میشه.
به صورت بازگشتی باید تابع cost رو اجرا کنید:
[tex]cost(i,j)=C_{i, j}+\max\{cost(i+1, j),\: cost(i, j+1)\}[/tex]
فکر نکنم این الگوریتم درست باشه
ممکنه در جهت راست که حرکت میکنه تعداد سکه کمتری نسبت به جهت پایین باشه ولی تو ادامه مسیر تعداد سکه های اون قسمت بیشتر باشه
یا جواب رو با دقت نخوندید یا dynamic programming رو بلد نیستید.
در فرمول ننوشتم که [tex]cost(i,\: j)=C_{i,\: j}+\max\{C_{i+1,\: j},\: C_{i,\: j+1}\}[/tex]
نوشتم [tex]cost(i,j)=C_{i, j}+\max\{cost(i+1, j),\: cost(i, j+1)\}[/tex]. وقتی به صورت بازگشتی اجرا میشه، خود اون تابعهای cost این مشکلی که شما گفتید رو حل میکنند، چون تا آخرش اون مسیر رو به صورت انشعابی ادامه میدهند!
روی یک ماتریس ۳ در ۳ امتحان کنید. تابع [tex]cost(0,0)[/tex] به تابعهای [tex]cost(0,1)[/tex] و [tex]cost(1,0)[/tex] منشعب میشه که تابع [tex]cost(0,1)[/tex] خودش به [tex]cost(1,1)[/tex] و [tex]cost(0,2)[/tex] تبدیل میشه (همچنین تابع منشعب دوم، یعنی [tex]cost(1,0)[/tex] هم خودش دو تا میشه و هر کدوم دنبال ماکزیمم میگردند...)
درسته من اشتباه تحلیل کردم
ممنون
ارسال: #۶
  
RE: پیدا کردن با ارزش ترین مسیر در یک ماتریس
(۱۶ خرداد ۱۳۹۵ ۰۹:۲۹ ب.ظ)kamal3401 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۹:۲۰ ب.ظ)behnam5670 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۹:۱۱ ب.ظ)kamal3401 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۸:۵۶ ب.ظ)behnam5670 نوشته شده توسط:(16 خرداد ۱۳۹۵ ۰۸:۲۱ ب.ظ)kamal3401 نوشته شده توسط: سلام من یک سوالی دیدم و نمیدونم به کدووم بحث طراحی الگوریتم مربوط میشه!! احساس میکنم این مسئله جزو مسئله های مهم و کاربردی طراحی الگوریتم
فرض میکنیم یک ماتریسی داریم در ابعاد N*M که تو هر کدوم از خانه های این ماتریس به تعداد [tex]C_{i.j}[/tex] سکه وجود داره!!
حالا عامل هوشمندی رو وارد ماتریس میکنیم که از محل یک و یک شروع به حرکت میکنه تا به محل N*M برسه
این عامل هوشمند فقط میتونه در دو جهت حرکت کنه(یک خانه به سمت راست یا یک خانه به سمت پایین)
الگوریتمی پیدا کنید که این عامل هوشمند در مسیری حرکت کند که حاوی بیشترین تعداد سکه باشد
این مسأله با dynamic programming حل میشه.
به صورت بازگشتی باید تابع cost رو اجرا کنید:
[tex]cost(i,j)=C_{i, j}+\max\{cost(i+1, j),\: cost(i, j+1)\}[/tex]
فکر نکنم این الگوریتم درست باشه
ممکنه در جهت راست که حرکت میکنه تعداد سکه کمتری نسبت به جهت پایین باشه ولی تو ادامه مسیر تعداد سکه های اون قسمت بیشتر باشه
یا جواب رو با دقت نخوندید یا dynamic programming رو بلد نیستید.
در فرمول ننوشتم که [tex]cost(i,\: j)=C_{i,\: j}+\max\{C_{i+1,\: j},\: C_{i,\: j+1}\}[/tex]
نوشتم [tex]cost(i,j)=C_{i, j}+\max\{cost(i+1, j),\: cost(i, j+1)\}[/tex]. وقتی به صورت بازگشتی اجرا میشه، خود اون تابعهای cost این مشکلی که شما گفتید رو حل میکنند، چون تا آخرش اون مسیر رو به صورت انشعابی ادامه میدهند!
روی یک ماتریس ۳ در ۳ امتحان کنید. تابع [tex]cost(0,0)[/tex] به تابعهای [tex]cost(0,1)[/tex] و [tex]cost(1,0)[/tex] منشعب میشه که تابع [tex]cost(0,1)[/tex] خودش به [tex]cost(1,1)[/tex] و [tex]cost(0,2)[/tex] تبدیل میشه (همچنین تابع منشعب دوم، یعنی [tex]cost(1,0)[/tex] هم خودش دو تا میشه و هر کدوم دنبال ماکزیمم میگردند...)
درسته من اشتباه تحلیل کردم
ممنون
خواهش میکنم.
به عنوان تمرین اگر خواستی مسأله رو برای حالتی حل کن که امکان حرکت به بالا هم داشته باشی (منتهی هر خونه نباید بیشتر از یک بار ویزیت بشه، لذا نمیتونی فقط یه جمله اضافه کنی که مثلاً [tex]cost(i-1,\: j)[/tex] رو هم بیاری داخل ماکزیمم. روشش فرق میکنه)
Can I see some ID?
Feeling left out?
نگران نباش، فقط روی این لینک برای ثبت نام کلیک کن. رمزت رو فراموش کردی؟ اینجا به یادت میاریم! close