Алгоритм Рюкзака

Меню сайта

Статистика
Рейтинг@Mail.ru Яндекс.Метрика

Алгоритм рюкзака на C++

 

#include <vector>
#include <limits>

   int knapsack2(const std::vector<int>& wts, const std::vector<int>& cost, int W)
     {
     size_t n = wts.size();
     std::vector<std::vector<int> > dp(W + 1);
     for (int i = 0; i <= W; i++)
     {
     dp[i].resize(n + 1);
     dp[i][0] = 0;
     }
     for (size_t i = 0; i <= n; i++)
     {
     dp[0][i] = 0;
     }
     for (size_t j = 1; j <= n; j++)
     {
     for (int w = 1; w <= W; w++)
     {
     if (wts[j-1] <= w)
     {
     dp[w][j] = std::max(dp[w][j - 1], dp[w - wts[j-1]][j - 1] + cost[j-1]);
     } else
     {
     dp[w][j] = dp[w][j - 1];
     }
     }
     }
return dp[W][n];

}




Назад Домой Вперед

 

 

Друзья сайта
  • Группа AR в ВК
  • Группа AR в FB
  • Группа AR в OK
  • Алгебра Логики
  • Альтернатива Групп
  • Портал муз. педагога

  • Фрейм


    Алгоритм Рюкзака © 2025 created AD.