У меня есть 2 списка разной длины. Подарок выбирается и присваивается имени, затем следующий подарок вручается следующему имени, и так по кругу, пока подарки не закончатся.
gifts = ['pencil', 'pen', 'book', 'notebook', 'pencil_box', 'schoolbag', 'stick']
name = ['John', 'Marcus', 'Marie']
Ожидаемый результат:
John: pencil notebook stick
Marcus: pen pencil_box
Marie: book schoolbag
Другой пример:
gifts = ['car', 'house', 'phone']
name = ['RichieRich']
Ожидаемый результат:
RichieRich: car house phone
Немного помощи?
Это возможно с помощью циклов for:
count = 0
kids = [yourkids]
gifts = [yourgifts]
outputKids = kids
for gift in gifts:
if count > kids.length:
count = 0;
outputKids[count].push(gift)
count = count + 1
Затем просто сопоставьте свой массив «детей» с «outputKids» (по индексу), и у вас есть подарки для каждого ребенка.
Ну вот:
from itertools import cycle
from collections import defaultdict
gifts = ['pencil', 'pen', 'book', 'notebook', 'pencil_box', 'schoolbag', 'stick']
names = ['John', 'Marcus', 'Marie']
gifts_by_name = defaultdict(list)
for name, gift in zip(cycle(names), gifts):
gifts_by_name[name].append(gift)
for name in names:
print '%s: %s' % (name, " ".join(gifts_by_name[name]))
Прошу прощения, я сделал это в javascript: P