Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/18: Рейтинг темы: голосов - 18, средняя оценка - 4.89
45 / 29 / 1
Регистрация: 05.02.2011
Сообщений: 388

Алгоритм прямой и обратной прогонки (динамическое программирование)

22.12.2016, 20:06. Показов 3727. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Есть задача: Фермер имеет k овец. В конце каждого года он принимает решение, сколько овец продать и сколько оставить. Прибыль от продажи одной овцы в i-й год равна р[i]. Количество овец в конце i-го года удваивается к концу (i+1)-го года. Фермер планирует в конце n-го года полностью продать овец. Необходимо получить общее рекуррентное уравнение для решения задачи.Решить задачу при следующих данных: n = 3 года, k = 2 овцы, p1 = 100, р2 = 130, p3 = 120.
Нашел небольшую теорию, где есть некоторое описание (оно во вложении), но не совсем понятен ход решения.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package trp3;
 
public class t {
 
      public static void main(String[] args){
          int n = 3;
          int k = 2;
          int p[] = new int[n+1];
          p[1] = 100;
          p[2] = 130;
          p[3] = 120;
          int nk = 16;
          int f[][] = new int[nk+1][nk+1];
          int y[] = new int[nk+1];
          int z[] = new int[nk+1];
          
          for (z[n]=0;z[n]<=nk; z[n]++){
              y[n] = z[n];
              f[n][z[n]] = p[n]*y[n];
              System.out.print(f[n][z[n]]+" ");
          }
          System.out.println();
        int value = 0;
          for (int j=n-1; j>=0; j--){
              int mk = (int) (Math.pow(2, j)*k);
              
              for (z[j]=0; z[j]<=mk; z[j]++){
                int max = 0;
                  for (y[j]=0; y[j]<=z[j]; y[j]++){
                      value = p[j]*y[j]+f[j+1][2*(z[j]-y[j])];
                      System.out.println(p[j]*y[j]);
                    //  System.out.print(value+" ");
                      if (value>max) max = value;
                  }
                f[j][z[j]] = max;
             System.out.println();
              }
            
          }
          for (int i=0; i<=n; i++) {
              for (int j=0; j<=nk; j++) {
              System.out.print(f[i][j]+" ");
          }
            System.out.println();
      }
      }
}
Скажите пожалуйста, правильны ли вычисления и что нужно поменять? Я пробовал делать обратную прогонку
Вложения
Тип файла: docx 2.docx (21.8 Кб, 11 просмотров)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.12.2016, 20:06
Ответы с готовыми решениями:

Метод прямой прогонки. Динамическое программирование
надо написать прогу, которая искала бы кратчайший путь из одного конца неориентированного графа в другой путем прямой прогонки. я...

Динамическое программирование. Метод прямой прогонки
Мне нужно реализовать граф с поиском минимального пути из начала графа в конец путем прямой прогонки.Сделал граф, как список ребер,...

Нужна задача для курсовой "Динамическое программирование. Метод обратной прогонки"
Для моей курсовой работы нужно реализовать алгоритм в VBA по теме: &quot;Динамическое программирование. Метод обратной прогонки&quot; Но я не...

3
45 / 29 / 1
Регистрация: 05.02.2011
Сообщений: 388
22.12.2016, 20:33  [ТС]
Здесь в задаче требуется определить, в каком году сколько нужно продавать овец, чтобы получить максимальную прибыль
0
3 / 3 / 2
Регистрация: 21.12.2016
Сообщений: 8
22.12.2016, 23:33
Просто перебери все варианты. Не забывай удваивать количество оставшихся овец.
Сначала не продавай овец и посчитай прибыль от продажи в конце.
Потом продай одну овцу в n-й год, и получишь n прибылей.
Потом продавай две овцы, одну в n-й год, одну в m-й. Получишь n^2 прибылей, где n - количество лет.
Потом три, четыре, и так пока овцы не кончатся.
Прибыли хранить не обязательно, достаточно хранить максимальную прибыль и стратегию ее достижения, т.е. массив, куда пишешь сколько овец нужно продавать в каждый год.

В простом варианте можно написать фиксированное решение - всего 3 цикла.
Нефиксированное, универсальное - 2 цикла и рекурсия.
0
45 / 29 / 1
Регистрация: 05.02.2011
Сообщений: 388
23.12.2016, 11:25  [ТС]
Цитата Сообщение от Ixb3k Посмотреть сообщение
Сначала не продавай овец и посчитай прибыль от продажи в конце.
Это вычислил, для k=2 овец максимум за 3 года можно получить 16 овец и прибыль за продажу равно 16*120 = 1920.
Цитата Сообщение от Ixb3k Посмотреть сообщение
Потом продай одну овцу в n-й год, и получишь n прибылей.
Это имеется ввиду продавать в последний n-й год или продавать во все года от 1 до n?
Цитата Сообщение от Ixb3k Посмотреть сообщение
Потом продавай две овцы, одну в n-й год, одну в m-й. Получишь n^2 прибылей, где n - количество лет.
Если продавать 2 овцы, то получается если хранить прибыль, то нужен двумерный массив? А если продавать 3 - то трехмерный?
Цитата Сообщение от Ixb3k Посмотреть сообщение
достаточно хранить максимальную прибыль и стратегию ее достижения, т.е. массив, куда пишешь сколько овец нужно продавать в каждый год.
Я пробовал писать в коде на Java вычисления максимальной прибыли в двумерном массиве по формуле, которая на скриншоте снизу.
Вот код (здесь 3 цикла):
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
    int value = 0;
          for (int j=n-1; j>=0; j--){
              int mk = (int) (Math.pow(2, j)*k);
              
              for (z[j]=0; z[j]<=mk; z[j]++){
                int max = 0;
                  for (y[j]=0; y[j]<=z[j]; y[j]++){
                      value = p[j]*y[j]+f[j+1][2*(z[j]-y[j])];
                      System.out.println(p[j]*y[j]);
                    //  System.out.print(value+" ");
                      if (value>max) max = value;
                  }
                f[j][z[j]] = max;
             System.out.println();
              }
            
          }
Скажите пожалуйста, что еще можно добавить или изменить в коде?
Миниатюры
Алгоритм прямой и обратной прогонки (динамическое программирование)  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.12.2016, 11:25
Помогаю со студенческими работами здесь

Метод обратной прогонки
Нужно реализовать метод обратной прогонки на с++.МОЖНО ВЗЯТЬ ЛЮБОЙ ПРИМЕР.КТО МОЖЕТ ПОМОГИТЕ!!

Решение задач динамического программирования методом прямой прогонки
Рассмотреть на любых 2-х примерах. Составить программу на выбор на Pascal,C,C++,C#

Решение задач динамического программирования методом прямой прогонки
Рассмотреть на любых 2-х примерах(придумать самому). Составить программу(две) на выбор на Assembler, или любых других удобных для вас языках

Алгоритм и код программы решения уравнения Пуассона методом матричной прогонки
Объясните, пожалуйста алгоритм и код на Си++ задачи: ∂2P/∂x2+∂2P/∂y2=-f(x,y)

Алгоритм решения уравнения методом прогонки для 3х многого случая.СРОЧНО!
СРОЧНО!!! Помогите пожалуйста кто сможет))) Дано дифференциальное уравнение, которое описываете распределение радона в пористой среде...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru