>  기사  >  백엔드 개발  >  itertools.combinations()에 의해 생성된 튜플을 효율적으로 스크램블하는 방법은 무엇입니까?

itertools.combinations()에 의해 생성된 튜플을 효율적으로 스크램블하는 방법은 무엇입니까?

PHPz
PHPz앞으로
2024-02-22 12:43:11646검색

如何有效地打乱 itertools.combinations() 生成的元组?

질문 내용

itertools.combinations()을 사용하여 반복되지 않는 요소 목록을 기반으로 두 항목 튜플 목록을 생성하고 있습니다. 그런 다음 결과 목록을 섞습니다. 그러나 튜플 자체의 내용은 시간순으로 구성됩니다. 예를 들어 다음 코드를 실행합니다.

으아악

출력:

으아악

문자는 입력 목록에 나타난 시간을 기준으로 튜플에서 정렬됩니다(알파벳순이 아니라 입력 목록이 우연히 알파벳순으로 정렬됩니다. 목록을 섞는다고 해서 문제가 해결되지는 않고 숨길 뿐입니다). "c"는 항상 "d"의 왼쪽에 나타나고 "a"는 항상 다른 모든 것의 왼쪽에 나타납니다.

내 해결책은 모든 튜플을 스크램블된 튜플로 간단히 바꾸는 것이었습니다(아래 참조). 이는 작동하지만 특히 큰 목록에서는 속도가 매우 느린 것으로 나타났습니다.

으아악

유사한 출력을 더 빠르게 생성할 수 있는 방법이 있나요?


정답


각 튜플을 섞는 대신 무작위로 튜플을 선택하여 되돌리는 것이 훨씬 빠르게 작동합니다. item_combos의 각 튜플에는 항목이 두 개만 포함되므로 결과는 동일합니다.

새로운 튜플 "스크램블링" 코드:

으아악

위 내용은 itertools.combinations()에 의해 생성된 튜플을 효율적으로 스크램블하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제