2010-02-19 3 views
5

Предположим, у меня есть 4 слова, как строка. Как мне присоединиться ко всем этим?Сочетание слов в Python (перестановки?)

s = orange apple grapes pear 

Результат будет строка:

"orangeapple/orangegrapes/orangepear/applegrapes/applepear/grapespear/orangeapplegrapes/orangeapplepear/applegrapespear" 

Я имею в виду:

list_words = s.split(' ') 
for l in list_words: 

, а затем использовать перечисления? Это то, что вы использовали бы для выполнения этой функции?

+0

ли порядок в результате важного? –

+0

Нет, но я предполагаю, что это упростит ситуацию, не так ли? (Я просто новый с Enumerate) – TIMEX

+0

Вы также хотите, чтобы апельсиновый сок, виноград, груша? Это сделало бы ваш вопрос более полезным. – forefinger

ответ

4

Возможно, это то, что вы хотите?

s = "orange apple grapes pear" 

from itertools import product 
l = s.split() 
r='/'.join(''.join(k*v for k,v in zip(l, x)) 
      for x in product(range(2), repeat=len(l)) 
      if sum(x) > 1) 
print r 

Если работать на 'ABC' (для ясности) результат является:

bc/ac/ab/abc 

(Обновлено после комментария от плаката.)

+0

Как это изменится, если я хочу только соединенные слова? Другими словами, я не хочу " «только», «b» или «c». (Только связанные слова). Спасибо. – TIMEX

+0

Обновленный ответ для ваших новых требований. –

1
s = 'orange apple grapes pear' 

list_words = s.split() 

num = len(list_words) 
ans = [] 
for i in xrange(1,2**num-1): 
    cur = [] 
    for j,word in enumerate(list_words): 
    if i & (1 << j): 
     cur.append(word) 
    if len(cur) > 1: 
    ans.append(''.join(cur)) 
print '/'.join(ans) 

Это дает все подмножества списка слов, кроме пустого, одиночных слов и всех них. Для примера: orangeapple/orangegrapes/applegrapes/orangeapplegrapes/orangepear/applepear/orangeapplepear/grapespear/orangegrapespear/applegrapespear

+0

спасибо за подсказку – TIMEX

1
>>> import itertools 
>>> from itertools import combinations 
>>> s = "orange apple grapes pear".split() 
>>> res=[] 
>>> for i in range(2,len(s)+1): 
...  res += [''.join(x) for x in combinations(s,i)] 
... 
>>> '/'.join(res) 
'orangeapple/orangegrapes/orangepear/applegrapes/applepear/grapespear/orangeapplegrapes/orangeapplepear/orangegrapespear/applegrapespear/orangeapplegrapespear' 
1
>>> s = "orange apple grapes pear".split() 
>>> '/'.join(''.join(k) for k in [[s[j] for j in range(len(s)) if 1<<j&i] for i in range(1<<len(s))] if len(k)>1) 
'orangeapple/orangegrapes/applegrapes/orangeapplegrapes/orangepear/applepear/orangeapplepear/grapespear/orangegrapespear/applegrapespear/orangeapplegrapespear' 
4
>>> from itertools import combinations 
>>> s = "orange apple grapes pear".split() 
>>> '/'.join([''.join(y) for y in [ x for z in range(len(s)) for x in combinations(s,z)] if len(y)>1]) 
'orangeapple/orangegrapes/orangepear/applegrapes/applepear/grapespear/orangeapplegrapes/orangeapplepear/orangegrapespear/applegrapespear' 
+0

Да, +1: комбинации - хороший выбор здесь. –

Смежные вопросы