>백엔드 개발 >파이썬 튜토리얼 >Python에서 목록 요소의 가능한 모든 조합을 어떻게 생성할 수 있습니까?

Python에서 목록 요소의 가능한 모든 조합을 어떻게 생성할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-19 09:27:09838검색

How Can I Generate All Possible Combinations of a List's Elements in Python?

목록 요소의 가능한 모든 조합 생성

목록에서 가능한 모든 2^N 조합을 생성하는 방법을 찾고 있습니다. 원래 순서를 유지하면서 어떤 길이의 조합도 수용할 수 있는 15개 요소 목록입니다. 이진 표현과 관련된 접근 방식은 실행 가능한 옵션이지만 보다 포괄적인 솔루션을 살펴보겠습니다.

이진 표현에 의존하는 대신 Python 표준 라이브러리의 itertools.combinations() 함수를 사용하는 것이 좋습니다. 이 함수는 주어진 반복 가능 항목에서 주어진 길이의 모든 조합 시퀀스를 생성합니다. 길이 매개변수를 변경하면 원하는 크기의 조합을 얻을 수 있습니다.

다음 Python 코드는 이 접근 방식을 보여줍니다.

import itertools

stuff = [1, 2, 3]

# Loop through all possible lengths
for L in range(len(stuff) + 1):
    # Generate combinations of length L
    for subset in itertools.combinations(stuff, L):
        print(subset)

이 코드는 요소의 가능한 32,768가지 조합을 모두 생성합니다. 길이에 관계없이 항목 목록을 삭제합니다.

또는 보다 효율적인 솔루션을 위해 chain() 및 Combinations() 함수는 가능한 모든 길이의 모든 조합을 포함하는 단일 시퀀스를 생성합니다.

import itertools

from itertools import chain, combinations

def all_subsets(ss):
    return chain(*map(lambda x: combinations(ss, x), range(0, len(ss)+1)))

for subset in all_subsets(stuff):
    print(subset)

이 코드는 동일한 결과를 달성하지만 더 간결하고 틀림없이 우아한 방식으로 이루어집니다.

위 내용은 Python에서 목록 요소의 가능한 모든 조합을 어떻게 생성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.