Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 17.02.2020
Сообщений: 2
1

Задача о рюкзаке методом ПОИСКА ПО ШИРИНЕ python

17.02.2020, 02:43. Показов 802. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Python
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
import time
start = time.time()
from queue import Queue
from queue import LifoQueue
from copy import copy
class Uzel:
    def __init__(self,id,ben,weight,ben1,weight1):
        self.id = id
        self.ben = ben
        self.weight =  weight
        self.ben1 = ben1
        self.weight1 = weight1
id = []
ben = 0
weight = 0
ben1 = 0
weight1 = 0
class Solution:
    def __init__(self,id, ben, weight):
        self.id = id
        self.fb = ben
        self.fw = weight
id = []
ben = 0
weight = 0
das = Solution(id, ben, weight)
def BFS():
    items=[[20, 15], [40, 32], [50, 60], [36, 80], [26, 43], [64, 120], [54, 77], [18, 6], [46, 93], [28, 35], [25, 37]]
    forcheck = []
    for i in range(0,len(items)):
        forcheck.append(-1)
    ocher = Uzel(forcheck, 0, 0, 0, 0)
    queue = Queue()
    queue.put(ocher)
    depth = len(items)
    while queue.empty()==False:
        node = queue.get()
        if is_solution(node):
            for i in range (0, len(forcheck)):
                if node.id[i] == -1:
                    depth = i
            mweight=420
            if (node.weight1+items[depth][1]) <= mweight:
                ord = copy(node.id)
                ord[depth] = 0
                bala = Uzel(ord, items[depth][0], items[depth][1], node.ben1, node.weight1)
                queue.put(bala)
                solution_1 = copy(node.id)
                solution_1[depth] = 1
                bala = Uzel(solution_1, items[depth][0], items[depth][1], node.ben1 + items[depth][0], node.weight1 + items[depth][1])
                queue.put(bala)
        if das.fb < node.ben1:
            das.id = node.id
            das.fb = node.ben1
            das.fw = node.weight1
        final = []
        sol = das.id
        for i in range (0, len(sol)):
            if sol[i] == 1:
                final.append(i+1)
    print(final, das.fb, das.fw)
def is_solution(node):
    for i in range (0, len(node.id)):
        if node.id[i] == -1:
            return True
    return False
print("BFS:")
BFS()
print("DFS:")
DFS()
end = time.time()
print(end - start)
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.02.2020, 02:43
Ответы с готовыми решениями:

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

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

Задача о рюкзаке методом динамического программирования, исправить код
Помогите разобраться! Написал прогу, которая должна решать задачу о рюкзаке методом Беллмана...

Задача о рюкзаке методом динамического программирования. Обратный ход
Есть такая задача: Задача о рюкзаке(англ. Knapsack problem) — дано N предметов, n_i предмет имеет...

1
0 / 0 / 0
Регистрация: 17.02.2020
Сообщений: 2
17.02.2020, 13:25  [ТС] 2
подскажите пожалуйста как по другому можно написать дынный код на пайтон???
0
17.02.2020, 13:25
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.02.2020, 13:25
Помогаю со студенческими работами здесь

Задача о рюкзаке методом полного перебора. Нужно пояснение по коду
Здравствуйте, нужно пояснение по этому коду. Код не мой, также в нем много ошибок. Заранее спасибо....

Задача о рюкзаке: какую наибольшую стоимость могут иметь предметы в рюкзаке?
Нужно решение обычной задачи о рюкзаке методом динамического программирования. С вводом с...

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

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

задача на перестановку кубиков методом поиска в ширину
работающая программа есть,но нужно переделать,чтоб список кубиков вводить самому.. domains...

Задача о загрузке самолета(задача о рюкзаке)
Есть задача о загрузке самолета:Самолет имеет максимальную грузоподъемность...

Задача о рюкзаке
Имеются m предметов с номерами от 0 до m-1, для каждого из которых известна масса в килограммах pj...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru