Size: a a a

Сообщество Python Программистов

2021 January 04

DD

Danylo Dymarchuk in Сообщество Python Программистов
r=3 =>[['3', '3']]
источник

A

Alexander in Сообщество Python Программистов
def combinations(iterable, r: int):
   pool = tuple(iterable)
   n = len(pool)
   r = n if r is None else r
   if r > n:
       return
   indices = list(range(n))
   cycles = list(range(n, n - r, -1))
   yield tuple(pool[i] for i in indices[:r])
   while n:
       for i in reversed(range(r)):
           cycles[i] -= 1
           if cycles[i] == 0:
               indices[i:] = indices[i + 1:] + indices[i:i + 1]
               cycles[i] = n - i
           else:
               j = cycles[i]
               indices[i], indices[-j] = indices[-j], indices[i]
               yield tuple(pool[i] for i in indices[:r])
               break
       else:
           return
источник

A

Alexander in Сообщество Python Программистов
так точно работает, но тебе скажут, что ты списал =)
источник

A

Alexander in Сообщество Python Программистов
если найдешь, откуда - дам карму)
источник

КБ

Кирилл Баст... in Сообщество Python Программистов
Alexander
def combinations(iterable, r: int):
   pool = tuple(iterable)
   n = len(pool)
   r = n if r is None else r
   if r > n:
       return
   indices = list(range(n))
   cycles = list(range(n, n - r, -1))
   yield tuple(pool[i] for i in indices[:r])
   while n:
       for i in reversed(range(r)):
           cycles[i] -= 1
           if cycles[i] == 0:
               indices[i:] = indices[i + 1:] + indices[i:i + 1]
               cycles[i] = n - i
           else:
               j = cycles[i]
               indices[i], indices[-j] = indices[-j], indices[i]
               yield tuple(pool[i] for i in indices[:r])
               break
       else:
           return
че то я совсем туплю, а как вызвать то эту функцию?
источник

A

Alexander in Сообщество Python Программистов
def combinations(iterable, r: int):
   pool = tuple(iterable)
   n = len(pool)
   r = n if r is None else r
   if r > n:
       return
   indices = list(range(n))
   cycles = list(range(n, n - r, -1))
   yield tuple(pool[i] for i in indices[:r])
   while n:
       for i in reversed(range(r)):
           cycles[i] -= 1
           if cycles[i] == 0:
               indices[i:] = indices[i + 1:] + indices[i:i + 1]
               cycles[i] = n - i
           else:
               j = cycles[i]
               indices[i], indices[-j] = indices[-j], indices[i]
               yield tuple(pool[i] for i in indices[:r])
               break
       else:
           return


if __name__ == "__main__":
   for i in combinations("abc",2):
       print(i)
источник

КБ

Кирилл Баст... in Сообщество Python Программистов
бля, я дебил
источник

EA

Eugene Artesius Pask... in Сообщество Python Программистов
Alexander
def combinations(iterable, r: int):
   pool = tuple(iterable)
   n = len(pool)
   r = n if r is None else r
   if r > n:
       return
   indices = list(range(n))
   cycles = list(range(n, n - r, -1))
   yield tuple(pool[i] for i in indices[:r])
   while n:
       for i in reversed(range(r)):
           cycles[i] -= 1
           if cycles[i] == 0:
               indices[i:] = indices[i + 1:] + indices[i:i + 1]
               cycles[i] = n - i
           else:
               j = cycles[i]
               indices[i], indices[-j] = indices[-j], indices[i]
               yield tuple(pool[i] for i in indices[:r])
               break
       else:
           return
Это не из итертулов?
источник

A

Alexander in Сообщество Python Программистов
Eugene Artesius Pasko
Это не из итертулов?
+10
источник

K

KarmaBot in Сообщество Python Программистов
Вы увеличили карму Eugene Artesius Pasko до 200.37 (+10.00)
источник

A

Alexander in Сообщество Python Программистов
это в доке прямо написан эквивалент itertools.permutations
источник

A

Alexander in Сообщество Python Программистов
источник

КБ

Кирилл Баст... in Сообщество Python Программистов
Alexander
def combinations(iterable, r: int):
   pool = tuple(iterable)
   n = len(pool)
   r = n if r is None else r
   if r > n:
       return
   indices = list(range(n))
   cycles = list(range(n, n - r, -1))
   yield tuple(pool[i] for i in indices[:r])
   while n:
       for i in reversed(range(r)):
           cycles[i] -= 1
           if cycles[i] == 0:
               indices[i:] = indices[i + 1:] + indices[i:i + 1]
               cycles[i] = n - i
           else:
               j = cycles[i]
               indices[i], indices[-j] = indices[-j], indices[i]
               yield tuple(pool[i] for i in indices[:r])
               break
       else:
           return


if __name__ == "__main__":
   for i in combinations("abc",2):
       print(i)
ээ, по моему оно не так работает как должно
источник

A

Alexander in Сообщество Python Программистов
причем, судя по аргументам функции - препод не заморачивался и попросил написать ее именно оттуда =)
источник

DD

Danylo Dymarchuk in Сообщество Python Программистов
Alexander
def combinations(iterable, r: int):
   pool = tuple(iterable)
   n = len(pool)
   r = n if r is None else r
   if r > n:
       return
   indices = list(range(n))
   cycles = list(range(n, n - r, -1))
   yield tuple(pool[i] for i in indices[:r])
   while n:
       for i in reversed(range(r)):
           cycles[i] -= 1
           if cycles[i] == 0:
               indices[i:] = indices[i + 1:] + indices[i:i + 1]
               cycles[i] = n - i
           else:
               j = cycles[i]
               indices[i], indices[-j] = indices[-j], indices[i]
               yield tuple(pool[i] for i in indices[:r])
               break
       else:
           return


if __name__ == "__main__":
   for i in combinations("abc",2):
       print(i)
В доке пайтоне такое же есть)))
источник

DD

Danylo Dymarchuk in Сообщество Python Программистов
источник

A

Alexander in Сообщество Python Программистов
Danylo Dymarchuk
В доке пайтоне такое же есть)))
это он и есть)
источник

A

Alexander in Сообщество Python Программистов
сверху же ссылка)
источник

DD

Danylo Dymarchuk in Сообщество Python Программистов
Alexander
если найдешь, откуда - дам карму)
Можно?)))
источник

A

Alexander in Сообщество Python Программистов
Danylo Dymarchuk
В доке пайтоне такое же есть)))
+10 раз нашел =)
источник