배열의 모든 순열 생성
고유한 요소의 배열이 주어지면 목표는 배열 요소의 가능한 모든 순열을 나열하는 것입니다.
알고리즘
다음 알고리즘은 O(N!) 시간에 모든 순열을 생성합니다. 복잡성:
- 초기화: i = 0으로 설정합니다.
- 배열에 대한 반복: i가 배열 길이보다 작은 경우:
- 교환: 인덱스 i의 요소를 각각 교환합니다.
- 재귀: i 1을 새 i 값으로 사용하여 알고리즘을 재귀적으로 호출합니다.
- 뒤로 바꾸기: 재귀 호출 후 요소를 원래 요소로 다시 바꿉니다. position.
- i 증가: i를 1씩 증가시킵니다.
Python 구현
def permute(arr, i=0): if i == len(arr) - 1: print(arr) return for j in range(i, len(arr)): arr[i], arr[j] = arr[j], arr[i] permute(arr, i + 1) arr[i], arr[j] = arr[j], arr[i]
Jarvis March 알고리즘
반복되는 요소가 있는 배열의 경우 Jarvis March 알고리즘이 더 효율적입니다. 접근 방식:
- 정렬: 배열을 오름차순으로 정렬합니다.
- 동안: 완료되지 않은 동안:
- 피벗 찾기: 요소가 해당 요소보다 작은 가장 큰 인덱스를 찾습니다. Successor.
- 인접 찾기: 정렬된 부분에서 피벗 인덱스의 요소보다 큰 마지막 요소를 찾습니다.
- 교환: 피벗과 인접한 요소를 교환합니다. indices.
- 역방향: 피벗 인덱스부터 정렬된 부분의 끝 부분까지 요소를 반전합니다.
- 완료 확인: 배열이 있는지 확인합니다. 내림차순으로 정렬됩니다. 그렇다면 루프를 종료하세요.
Python 구현
def permute_repeated(arr): ind = [0] * len(arr) for i in range(len(arr)): ind[i] = i while True: yield [arr[i] for i in ind] for i in range(len(arr) - 2, -1, -1): if ind[i] arr[i]: ind[i], ind[j] = ind[j], ind[i] break ind[i + 1:] = sorted(ind[i + 1:])
위 내용은 반복되는 요소가 있는 배열을 포함하여 배열의 모든 순열을 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
어 ass 신 크리드 그림자 : 조개 수수께끼 솔루션
3 몇 주 전ByDDD
Windows 11 KB5054979의 새로운 기능 및 업데이트 문제를 해결하는 방법
2 몇 주 전ByDDD
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

드림위버 CS6
시각적 웹 개발 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기
