Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.81/21: Рейтинг темы: голосов - 21, средняя оценка - 4.81
mmaksimus

Задача о рюкзаке на минимальную стоимость при полной загрузке

03.06.2013, 13:34. Показов 4314. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Имеется стандартная задача о рюкзаке с возможностью повторения предметов, вот мой код переделанный с C++ на C#, взятый отсюда.
C#
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
48
49
50
51
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace kursTPR1
{
    class kursTPR1
    {
        static void Main(string[] args)
        {
            int[] weights = new int[10]; //вес
            int[] costs = new int[10]; //цена
            int needed = 1000; //размер рюкзака
 
            weights[0] = 2; costs[0] = 1;
            weights[1] = 4; costs[1] = 5;
            weights[2] = 5; costs[2] = 7;
            weights[3] = 1; costs[3] = 3;
            weights[4] = 3; costs[4] = 4;
            weights[5] = 7; costs[5] = 6;
            weights[6] = 1; costs[6] = 3;
            weights[7] = 6; costs[7] = 5;
            weights[8] = 5; costs[8] = 2;
            weights[9] = 4; costs[9] = 5;
 
            knapsack(weights, costs, needed);
        }
 
        static void knapsack(int[] weights, int[] costs, int needed)
        {
            int n = weights.Length;
            int[] dp = new int[needed + 1];
            for (int i = 1; i <= needed; i++)
            {
                dp[i] = dp[i - 1];
                for (int j = 0; j < n; j++)
                {
                    if (weights[j] <= i)
                    {
                        dp[i] = Math.Max(dp[i], dp[i - weights[j]] + costs[j]);
                    }
                }
            }
            Console.WriteLine(dp[1000]);
            Console.ReadKey();
        }
 
    }
}
Помогите исправить код для нахождения минимальной суммарной цены при полной загрузке рюкзака(т.е. на 1000). Простое изменение Max на Min даёт нули на весь массив стоимостей(dp[]).
Для облегчения проверки правильности решения максимальная и минимальная сумма, посчитанные конкретно для этого кода равны 3000 и 400 соответственно. Выручайте, вторые сутки уже бьюсь, или ткните на реализацию уравнения Беллмана, считающую минимальную стоимость предметов при полной загрузке рюкзака.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.06.2013, 13:34
Ответы с готовыми решениями:

При полной загрузке GPU температура не поднимается
в тяжёлой игре при полной загрузке гпу, выше не поднимается i7 6700 без k, стоковый 60-63 GTX 1070 XTREME GAMING 70-73 PCH...

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

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

1
0 / 0 / 0
Регистрация: 22.10.2014
Сообщений: 11
24.02.2016, 20:43
А можешь подсказать , где тут исправить, чтобы без возможности повторения предметов?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.02.2016, 20:43
Помогаю со студенческими работами здесь

Адские тормоза хоста при полной загрузке гостевого процессора
В общем сабж. Когда гость полностью утилизирует ресурсы CPU, хостовая система встает колом: мышка двигается рывками, звук прерывается, даже...

При полной загрузке Пк выскакивает уведомление для подтверждения работы Cpu1.exe
В общем такая проблемка возникла, при полной загрузке Пк выскакивает уведомление для подтверждения работы Cpu1.exe после подтверждения...

Gtx660 - обороты кулера падают, когда загружается игра, а при полной загрузке вентилятор останавливается.
Привет, помогите с проблемкой. Есть видюха gtx660,которая при запуске игр(3d) категорически не хочет охлаждать себя. Обороты кулера...

При полной загрузке слотов оперативной памяти в материнку, происходят критические ошибки с "Экранами смерти"
Доброго времени суток! Хотелось бы узнать в чем проблема выскакиваний синих экранов смерти. Ошибки при этом очень разные, такие как: Kmode...

Найдите минимальную стоимость пути
На клетчатом поле размером m×n в левом нижнем углу лежит игральная кость. За один ход её можно перекатить на клетку вправо или вверх....


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru