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

Задача о рюкзаке

10.10.2013, 03:32. Показов 6199. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте уважаемые форумчане, все наверно слышали о проблеме о рюкзаке. Проблема следующая, имеется файл с данными, которые нужно прочитать и далее обработать, выглядит он следующим образом:

9000 4 100 18 114 42 136 88 192 3 223
9001 4 100 55 29 81 64 14 104 52 222
...

Где первая переменная ID, вторая кол-во предметов, третья - максимальный объем рюкзака, далее идут поочередно вес1 цена1 вес2 цена2 ...

В Java я новичок, и это первая домашка, столкнулся с проблемой что не могу прочесть файл и разделить его...
Код написан следующий:

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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package knapsack2;
 
import java.util.*;
 
class Knapsack2
{
public static void main (String args[]) // entry point from OS
{
MyClass myClass; // create dynamic entry point
myClass = new MyClass(new Scanner(System.in));
}
}
 
class MyClass {
 
MyClass (Scanner s)
{
Scanner ll;
int id;
Scanner ls;
int B[][];
int numItems, maxWeight, w, k;
int weight[], cost[];
int remainingWeight;
 
//*** Read in the initial numItems, maxWeight pair
ll = new Scanner(s.nextLine());
id = ll.nextInt();
 
ls = new Scanner(s.nextLine());
numItems = ls.nextInt();
maxWeight = ls.nextInt();
 
while ( (numItems != 0) && (maxWeight != 0) )
{
// *** Read in all the data for the items
cost = new int [numItems+1];
weight = new int [numItems+1];
ls = new Scanner(s.nextLine());
for (k = 1; k <= numItems; k++)
{
weight [k] = ls.nextInt();
cost [k] = ls.nextInt();
}
long lBegin = System.currentTimeMillis();
// *** initialize
B = new int [numItems+1][maxWeight+1];
for (w = 0; w <= maxWeight; w++)
B[0][w] = 0;
 
// *** Now do the work!
for (k = 1; k <= numItems; k++)
{
for (w = maxWeight; w >= weight[k]; w--)
if (cost[k] + B[k-1][w-weight[k]] > B[k-1][w])
B[k][w] = cost[k] + B[k-1][w-weight[k]];
else
B[k][w] = B[k-1][w];
for (w = 0; w < weight[k]; w++)
B[k][w] = B[k-1][w];
}
 
// *** Print out the results.
System.out.println("ID #" + id);
System.out.println("Max cost = " + B[numItems][maxWeight]);
System.out.print("Items used:");
for (k = numItems, remainingWeight=maxWeight; k > 0; k--)
{
if (remainingWeight >= weight[k])
if ( B[k][remainingWeight] == (cost[k] + B[k-1][remainingWeight - weight[k]]) )
{
System.out.print(" " + k);
remainingWeight -= weight[k];
}
}
System.out.println();
System.out.println();
 
// *** Read in the next numItems, maxWeight pair
ll = new Scanner(s.nextLine());
id = ll.nextInt();
 
ls = new Scanner(s.nextLine());
numItems = ls.nextInt();
maxWeight = ls.nextInt();
 
long lEnd = System.currentTimeMillis();
long lDelta = lEnd - lBegin;
}
 
}
 
} //** end of the "MyClass" class
Но в таком случае у меня получается читать данные в формате:
ID
number of items & max weight
weight1 cost1 weight2 cost2.

Вопрос к Вам, уважаемые, как можно переписать этот код, чтобы я мог брать всё необходимое из одной строки, и работать с данными, помогите кто может, пожалуйста, новичку. Я попытался по средством
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
String str = "";
String [] arrayStr = null;
 
while(s.hasNext()){
str = s.nextLine();
arrayStr = str.split(" ");
id =  = Integer.parseInt(arrayStr[0]);
numItems = Integer.parseInt(arrayStr[1]);
maxWeight = Integer.parseInt(arrayStr[2]);
 
cost = new int[numItems + 1];
weight = new int[numItems + 1];
w = 0; //начинаем заполнять массивы с нуля
k = 0;
 
for(int i = 3; i<arrayStr.length-1; i++){
cost[w++] = Integer.parseInt(arrayStr[i]); // массив содержащий цену
weight[k++] = Integer.parseInt(arrayStr[i+1]);
Но выдаёт ошибку. Заранее благодарен.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.10.2013, 03:32
Ответы с готовыми решениями:

Задача о рюкзаке
Помогите дана задача о рюкзаке. Надо решить на java. Методом ветвей и границ. Сам текст. Пример входного файла Первая цифра...

Задача о Рюкзаке. Полный перебор
Здравствуйте, решаю задачу о рюкзаке. Нашел здесь способ (https://en.wikipedia.org/wiki/Knapsack_problem#Dynamic_programming) как можно...

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

1
78 / 78 / 9
Регистрация: 28.10.2011
Сообщений: 219
10.10.2013, 21:08
Цитата Сообщение от viganti Посмотреть сообщение
rrayStr = str.split(" ");
я так подозреваю у вас проблемы с этой строкой , так как split принимает на вход регулярные выражения. (хоть утверждать не буду что причина именно в єтом)

попробуйте заюзать StringTokenizer
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.10.2013, 21:08
Помогаю со студенческими работами здесь

Задача о рюкзаке
нужно решить задачу о рюкзаке. n вещей с весом x и стоимостью z упаковать в рюкзак объема v. помогите плиз

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

Задача о рюкзаке
По данному набору из n предметов стоимостями v1,v2,...,vn и весами w1,w2,...,wn найти поднабор(с учетом того, что можно брать один предмет...

Задача о рюкзаке
Необходимо наполнить рюкзак определенной вместимости так, чтобы вещи в рюкзаке давали максимальную стоимость. Пытался делать через...

Задача о рюкзаке
Доброго вечера! Даны n типов предметов, каждый тип обладает своей стоимостью и весом, а также предел грузоподъемности limit. Нужно набрать...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru