재귀 및 비재귀 알고리즘을 사용하여 배열의 모든 순열을 어떻게 생성할 수 있습니까?
배열의 순열: 심층 설명
배열의 순열을 생성하려면 요소가 어떻게 배열되어 있는지 이해하는 것이 중요합니다. 순열에는 배열 요소를 재배열하여 새 시퀀스를 만드는 작업이 포함됩니다. n개의 요소가 있는 배열의 가능한 순열 수는 n!으로 제공됩니다.
재귀 알고리즘
순열을 생성하는 한 가지 방법은 재귀 접근 방식을 사용하는 것입니다. 반복적으로 요소를 교환하고 나머지 배열 요소에 순열을 적용합니다.
public static void permute(java.util.List<Integer> arr, int k) { for (int i = k; i < arr.size(); i++) { java.util.Collections.swap(arr, i, k); permute(arr, k + 1); java.util.Collections.swap(arr, k, i); } if (k == arr.size() - 1) { System.out.println(java.util.Arrays.toString(arr.toArray())); } }
로그인 후 복사
이 알고리즘은 시작됩니다. 첫 번째 요소를 나머지 요소 각각과 교환하여 그런 다음 나머지 요소에 동일한 작업을 반복적으로 적용합니다. 각 재귀 호출 후에 요소는 원래 위치로 다시 교체됩니다.
비재귀 알고리즘
반복 접근 방식의 경우 다음 단계를 고려하세요.
- 오름차순으로 정렬된 배열부터 시작하세요. order.
- 시퀀스가 내림차순이 아닌 첫 번째 인덱스를 찾습니다(예: a[i] < a[i-1]).
- 값이 내림차순인 마지막 인덱스를 찾습니다. a[i-1]보다 크거나 같습니다.
- a[i-1]을 마지막 요소와 교환합니다. index.
- 배열의 꼬리에 있는 요소 순서를 반대로 바꿉니다(인덱스 i-1 뒤).
예: 배열 순열 [3, 4, 6 , 2, 1]
재귀 알고리즘:
- 3을 4로 바꾸기: [4, 3, 6, 2, 1]
- 재귀적으로 [4, 3, 6, 2, 1] 치환
- 3을 6으로 바꾸기: [4, 6, 3, 2, 1]
- 재귀적으로 순열 [4, 6, 3, 2, 1]
- 모든 순열이 생성될 때까지 계속
비재귀적 알고리즘:
- [1, 2, 3, 4, 6]으로 시작(오름차순 정렬)
- 순서가 내림차순이므로 3단계로 진행
- a[i] < a[i-1]: i = 4, 3 < 4
- a[j] >= a[i-1]: j = 5인 마지막 인덱스를 찾습니다. 6 >= 3
- a[i-1]을 다음과 교체합니다. a[j]: [1, 2, 6, 3, 4, 5]
- 배열의 꼬리를 뒤집습니다: [1, 2, 3, 4, 5, 6]
- 배열이 내림차순이 될 때까지(모든 순열이 생성되었음을 나타냄) 3~6단계를 반복합니다.
두 알고리즘의 결과 동일합니다. 가능한 모든 순열이 생성되고 인쇄됩니다.
위 내용은 재귀 및 비재귀 알고리즘을 사용하여 배열의 모든 순열을 어떻게 생성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 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 몇 주 전
By DDD
Windows 11 KB5054979의 새로운 기능 및 업데이트 문제를 해결하는 방법
2 몇 주 전
By DDD
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전
By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

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

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

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

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제
Gmail 이메일의 로그인 입구는 어디에 있나요?
7549
15


Cakephp 튜토리얼
1382
52


Steam의 계정 이름 형식은 무엇입니까?
83
11


Win11 활성화 키 영구
57
19


NYT 연결 힌트와 답변
22
90

