Я пытаюсь создать функцию на питоне, которая может рассчитать наиболее эффективные способы упаковки предметов. большой пакет будет вмещать 25 предметов, а маленький пакет - 5 предметов.
def packages_needed (предметы, big_pack, small_pack)
Я действительно застрял в том, как определить/настроить рассуждение
то, о чем я думаю, - это установить условие, при котором x / a - целое число, тогда z будет просто этим. а если остаток не равен 0, то z будет целым числом плюс остаток.
Я не уверен, что мои рассуждения имеют смысл, но я был бы очень признателен за любые предложения/помощь.
что у меня есть до сих пор:
z = 0
x = large_pack
y= small_pack
for a in items:```
Чтобы разделить число на целую и дробную части, вы можете использовать x_int, x_frac = divmod(x,1)
Когда есть < 25 элементов, какие результаты вы хотите? 1 большая упаковка или несколько маленьких? 7 например. А 13? Для этого потребуется 3 маленькие упаковки или 1 большая упаковка.
@mr_mooo_cow Я пытаюсь настроить функцию, в которой сначала будут использоваться большие пакеты, а затем маленькие пакеты для оставшихся. например если у меня 80 предметов, то я хочу сначала использовать 3 большие упаковки, а затем 1 маленькую упаковку
Это не ответ на мой вопрос. Я говорю, если у вас есть 6 предметов, вы хотите 1 большую упаковку?
@mr_mooo_cow извините, я неправильно понял ваш вопрос, да, если меньше 25, мне нужно использовать small_packs. Условие состоит в том, чтобы каждый пакет был полностью заполнен, если он используется.
Мой ответ решает ваш вопрос? Если нет, прокомментируйте это.
Большое спасибо @mr_mooo_cow, ваш ответ очень полезен :D
Вы можете использовать стандартный оператор этажа разделения (//), чтобы определить, сколько раз количество предметов помещается в большие и маленькие упаковки.
def division_ceiling(a: int, b: int) -> int:
"""
Accepts number of items. Returns how many small packs are needed.
"""
return -1 * (-a // b)
def packages_needed(items: int) -> (int, int):
"""
Accepts number of items. Returns tuple (large pack, small pack)
"""
large_size = 25
small_size = 5
large_packs = items // large_size
small_packs = division_ceiling(items - large_packs * large_size, small_size)
return (large_packs, small_packs)
"""
if you want 1-25 items to be 1 large pack then do this:
if items <= 25:
return (1, 0)
else:
large_packs = items // large_size
small_packs = division_ceiling(items - large_packs * large_size, small_size)
return (large_packs, small_packs)
"""
print(packages_needed(int(input("Number of items?"))))
Input: 31
Output: (1, 2)
Input: 6
Output: (0, 2)
Чтобы проверить, является ли число целым, вы можете использовать
isinstance(variable, int)
.