Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 17.11.2015
Сообщений: 4

Разъяснение алгоритмов задачи о рюкзаке для новичков

17.11.2015, 22:50. Показов 2357. Ответов 17
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть несколько алгоритмов решения задачи о рюкзаке. Не могли бы вы написать комментарии к ним объясняющие какая процедура для чего нужна? Заранее спасибо.
 Комментарий модератора 

Запрещено создавать темы в виде ссылок на задания или коды программ, расположенные на других сайтах.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
17.11.2015, 22:50
Ответы с готовыми решениями:

Задачи для новичков
В связи с онлайн обучением есть несколько задач (очень не хватает времени на решение), прошу дать аналогичные либо похожие решения,...

Задачи для новичков
Посоветуйте сайт или пособие,где находятся задачи по С++ и есть решения к ним.

Задачи для новичков
Дана матрица А с 2 строками и 10 столбцами. 1й элемент каждого столбца представляет собой объем одной из 10 деталей узла машины,а 2-й...

17
 Аватар для Mesteriis
599 / 237 / 69
Регистрация: 08.08.2015
Сообщений: 1,637
17.11.2015, 23:07
Vaganych, В лед раз проще код сюда через теги пиши, на много проще будет отвечать, там по сути алгоритма нет тупо циклы с условиями вывода, Может ты имеешь ввиду комментарии к коду?
0
0 / 0 / 0
Регистрация: 17.11.2015
Сообщений: 4
17.11.2015, 23:10  [ТС]
Да, очень бы хотелось пояснения по коду. Просто что откуда берется, я бы хотел знать как они действуют. Желательно поподробнее, я совсем еще зеленый.
0
Dimension
595 / 463 / 223
Регистрация: 08.04.2014
Сообщений: 1,710
18.11.2015, 02:05
настолько зеленый ,что даже в гугле не можете вписать "задача о рюкзаке" ?попробуйте ,много нового для себя откроете
0
 Аватар для IrineK
2023 / 1641 / 425
Регистрация: 23.02.2011
Сообщений: 6,002
Записей в блоге: 25
18.11.2015, 02:54
Цитата Сообщение от Vaganych Посмотреть сообщение
я совсем еще зеленый.
Сортируешь грузы по возрастанию.
Начинаешь подбирать справа налево (от больших к маленьким), чего влезет в рюкзак. По ходу, если чего лезет, того и берёшь.
Всё.
0
0 / 0 / 0
Регистрация: 17.11.2015
Сообщений: 4
18.11.2015, 08:10  [ТС]
Я знаю как работает задача о рюкзаке, я просто хотел понять как работают именно те процедуры что я скинул.

Добавлено через 2 минуты
Как хотя бы работает эта процедура? Я понял как работает алгоритм на хабре потому что там все описано. А это даже не знаю.

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
52
53
54
55
56
57
58
59
60
61
#include <stdio.h>
#include <math.h>
 
int main() {
    int n = 6, s = 21, l = 0, g = 0, t = 0, s1 = 0, mk = 0;
    int q = pow(2,n/2) - 1;
    int r = (pow(2,n/2)*2);
    int a[6]= {1,3,8,5,10,12};
    int b[q][n]= {{0},{0}};
    int e[r] = {0};
 
    for(int i = 0; i < n; i++) {  
        for(int j = 0; j < n; j++) {   
                if (a[i] < a[j]) {
                    t = a[i];
                        a[i] = a[j];
                        a[j] = t;
                }
        }
    }
    for(int i = 0; i < pow(2,n/2); i++) {      
        for(int j = 0; j < n / 2; j++) {  // {0,1}
                b[i][j] = g%2;
                b[i][(n / 2)+j] = g%2;
                g /= 2;
        }
 
        l++;
        g = l; 
       
            for (int h = 0; h <  n / 2; h++) {
                e[i] = e[i] + a[h]*b[i][h];
                e[i+q+1] = e[i+q+1] + a[h+(n/2)]*b[i][h+(n/2)];
            }
    }
 
    for(int i = 0; i < pow(2,n / 2); i++) {
        for(int j = 0; j < pow(2,n /2); j++) {
            s1 = e[i] + e[j+1+q];
            if (s1 == s) {
                    for(int y = 0; y < n/2; y++){
                        if (b[i][y] != 0) {
                        printf("%d ", a[y]);
                    }  
                        if(b[j][y+n/2]!=0){
                                printf("%d ", a[y+n/2]);
                        }
                   }
               break;
            }                  
        }
        if (s1 == s) {
            break;
        }
    }  
    if (s1 != s) {
        printf("Elements not found\n");
    }
       
return 0;
}
0
4949 / 2289 / 287
Регистрация: 01.03.2013
Сообщений: 5,990
Записей в блоге: 32
18.11.2015, 08:43
Цитата Сообщение от IrineK Посмотреть сообщение
По ходу, если чего лезет, того и берёшь.
Это еврейский рюкзак получится. А нужен нормальный.
0
 Аватар для SmittWesson
236 / 196 / 21
Регистрация: 04.06.2014
Сообщений: 1,309
18.11.2015, 08:51
Цитата Сообщение от _Ivana Посмотреть сообщение
Это еврейский рюкзак получится. А нужен нормальный.
Ну, вот нормальный рюкзак.

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
#include <vector>
#include <limits>
 
//wts - массив весов, cost - массив стоимостей предметов, W - вместимость рюкзака
//функция возвращает максимальную стоимость, которую можно набрать(решение задачи о рюкзаке
//с повторениями)
 
int knapsack1(const std::vector<int>& wts, const std::vector<int>& cost, int W)
{
    size_t n = wts.size();
    std::vector<int> dp(W + 1);
    dp[0] = 0;
    for (int w = 1; w <= W; w++)
    {
        dp[w] = dp[w-1];
        for (size_t i = 0; i < n; i++)
        {
            if (wts[i] <= w)
            {
                dp[w] = std::max(dp[w], dp[w - wts[i]] + cost[i]);
            }
        }
    }
    return dp[W];
}
1
18.11.2015, 09:21

Не по теме:

Цитата Сообщение от _Ivana Посмотреть сообщение
Это еврейский рюкзак получится
- Рабинович, откуда у вас столько денег?
- Из тумбочки.
- А кто их туда кладет?
- Моя жена.
- Ну она-то где их берет?
- Я ей даю.
- А вы откуда берете?
- Из тумбочки.

0
18.11.2015, 09:40

Не по теме:

Цитата Сообщение от _Ivana Посмотреть сообщение
Это еврейский рюкзак получится. А нужен нормальный.
Это дискриминация рюкзаков по национальному признаку.

0
18.11.2015, 09:47

Не по теме:

Ну правильно, поскольку дискриминация = различение = классификация. Есть вот, к примеру, нормальное распределение. И китайская теорема об остатках, и венгерская нотация с польской записью. А вы привели еврейский алгоритм решения задачи о рюкзаке. Но существует и другой, который дает правильное решение задачи :)

0
18.11.2015, 11:07

Не по теме:

Цитата Сообщение от _Ivana Посмотреть сообщение
Есть вот, к примеру, нормальное распределение.
И остальные - ненормальные. Т.е., в вашей нотации - еврейские.
Но их же много! Или пойдём от колен израилевых?

0
18.11.2015, 11:21

Не по теме:

Все правильно - одноколенное, биколенное и мультиколенные распределения.

0
18.11.2015, 11:22

Не по теме:

Цитата Сообщение от IrineK Посмотреть сообщение
Т.е., в вашей нотации - еврейские.
а еще этот рюкзак чувства верующих оскорбляет

0
18.11.2015, 11:23

Не по теме:

Ага, верующих в нормальный работающий алгоритм :)

0
18.11.2015, 11:41

Не по теме:

Цитата Сообщение от _Ivana Посмотреть сообщение
верующих в нормальный работающий алгоритм
Аминь.

0
18.11.2015, 11:44
 Комментарий модератора 
Заканчиваем отходить от темы. Иначе оффтопа будет больше чем полезных сообщений.
0
0 / 0 / 0
Регистрация: 17.11.2015
Сообщений: 4
18.11.2015, 13:47  [ТС]
Ребят, а как например с помощью наивного алгоритма написать код на два рюкзака? С одним я уже разобрался (спасибо большое за код не перегруженный всякими ненужными переменными), но вот не знаю как будет выглядеть код на два и больше рюкзаков.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.11.2015, 13:47
Помогаю со студенческими работами здесь

Задачи для новичков
Создайте скрипт, который будет при клике на кнопку “ОК”, выводить указанное в поле ввода число смайликов на страницу.

Задачи для новичков
ВСем привет. У меня просьба. Вот сел я изучать шарп. Выучил базовые выражения, управляющие операторы. Хотелось бы в закрепление материалы...

Задачи для новичков
Создайте страницу, на которой будет 1 поле ввода текста и две кнопки: +1 и *2 Напишите скрипт, который работает по следующему...

Наивный алгоритм для задачи о рюкзаке
Всем привет помогите написать программу о рюкзаке c с помощью наивного алгоритма. Я начал, а дальше не совсем понимаю, что сделать нужно....

Динамическое программирование для задачи о рюкзаке
Здравствуйте, программа написана, но решение не верно. Помогите найти ошибку, пожалуйста! using System; using...


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

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
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