Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 15, средняя оценка - 4.87
serik13
3 / 3 / 0
Регистрация: 04.01.2011
Сообщений: 71
#1

С++. Дан рюкзак с заданным объемом... - C++

01.04.2011, 09:28. Просмотров 1950. Ответов 2
Метки нет (Все метки)

Кто сможет помогите с решением задачи на С++, буду очень благадарен.
Задача:
Дан рюкзак с заданным объемом и предметы со своим объемом и со своей определеной стоимостью.
Необходима сложить в рюкхаз предметы так чтобы они влезли,и чтобы их стоимость была максимальной.
Нужно срочно, буду очень благадарен.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.04.2011, 09:28     С++. Дан рюкзак с заданным объемом...
Посмотрите здесь:
C++ Удалить первый элемент с заданным объемом информации, добавить элемент перед элементом с указанным номером
C++ Доработка структуры (удалить первый элемент с заданным объемом информации, добавить элемент перед элементом с указанным номером)
Структура "Информация": - носитель; - объем; - название; - автор. Удалить первый элемент с заданным объемом информации, добавить элемент перед элемент C++
C++ Сверхвозрастающий рюкзак
непрерывный рюкзак C++
Задача про рюкзак C++
C++ Эвристика. Рюкзак Алладина.
Жадный алгоритм (рюкзак) C++
Задача про рюкзак C++
Задача о камнях (почти рюкзак) модификация) C++
Задача про рюкзак - ускорить работу программы C++
C++ Работа с большим объемом данных

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
IrineK
Заблокирован
01.04.2011, 11:14     С++. Дан рюкзак с заданным объемом... #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
#include <iostream>
#define B 15    //ограничение объема рюкзака по весу
#define k 5     //количество предметов
using namespace std;
 
int n,s;
int a[k]={6,4,3,2,5};   //вес предметов
int c[k]={5,3,1,3,6};   //стоимость 
int W[k+1][B+1];
 
void Print(int s, int n)
{
  if (W[s][n]==0) // максимальный рюкзак для параметров (s,n)
    return;        // имеет нулевую ценность
                   // поэтому ничего не выводим
  else if (W[s-1][n] == W[s][n]) 
    Print(s-1,n);  // можно составить рюкзак без предмета s
  else
  {                               
    Print(s-1,n-a[s]); // предмет s должен
    cout<<s<<endl;     // войти в рюкзак
  }
}
 
int main()
{
for(n=0;n<=B;n++)       // заполняем нулевой ряд
    W[0][n]=0;
for(s=1;s<=k;s++)       // s - максимальный номер предмета, 
{                       // который можно использовать
    for(n=0;n<=B;n++)   // n – объем рюкзака
    {
        W[s][n]=W[s-1][n]; 
        if ( n>=a[s-1] && ( W[s-1][n-a[s-1]]+c[s-1] > W[s][n]) )
            W[s][n] = W[s-1][n-a[s-1]]+c[s-1];
    }
}
cout<<"Array W(s)(n)"<<endl;
for(s=1;s<=k;s++)
{
    for(n=0;n<=B;n++)
        cout<<W[s][n]<<' ';
    cout<<endl;
}
cout<<endl;
cout<<"Rucksack includes these items:"<<endl;
Print(5,15);
cin.get();
return 0;
}
no0ker
101 / 88 / 4
Регистрация: 17.12.2010
Сообщений: 416
01.04.2011, 11:39     С++. Дан рюкзак с заданным объемом... #3
есть тут.
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru