2016-04-03 1 views
3

, что это чистый способ сделать следующее:вещий способ перебора множества/остатка установить

def foo(aSet) : 
    for a in aSet: 
     for remaining in aSet - {a} : 
      doSomething(a,remaining) 

Я имею в виду, должен быть какой-то способ записи, что как только один цикл?

+1

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

ответ

3
aSet = {1,2,3} 
[[i,j] for i in aSet for j in aSet if j != i] 
#=> [[1, 2], [1, 3], [2, 1], [2, 3], [3, 1], [3, 2]] 

В вашем случае вам нужен генератор

(doSomething(i, j) for i in aSet for j in aSet if j != i) 
3
>>> from itertools import permutations 
>>> aSet = {1, 2, 3} 
>>> list(permutations(aSet, 2)) 
[(1, 2), (1, 3), (2, 1), (2, 3), (3, 1), (3, 2)] 

>>> for a, remaining in permutations(aSet, 2): 
...  print(a, remaining, end=', ') 
... 
1 2, 1 3, 2 1, 2 3, 3 1, 3 2, 
Смежные вопросы