작성
·
27
답변 2
0
안녕하세요 ㅎㅎ
충분히 헷갈리실 수 있는 부분인데요.
순열로 하기 전에 (next_permutation) -> 먼저 sort()를 진행하기 때문에 정렬이 된 상태에서 진행이 됩니다.
예를 들어 3개에서 2개를 뽑는다고 했을 때
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1
이런식으로 순열이 생기게 됩니다.
이 때 두개를 앞에서부터 뽑게 되면 1 2 , 1 3, 2 1, 2 3 이렇게 뽑게 됩니다. 순서가 정렬된 상태로 뽑게 됩니다. 그 이후에 3 1 도 뽑게 되지만 이부분은 이미 1 3 때 처리를 했기 때문에 해당 경우의 수까지는 오지 않게 되는 것이죠
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다. 김현우님.
질문하신 내용은 next_permutation
함수 사용 시의 정렬 상태에 대한 것입니다. 이 함수는 주어진 범위 내의 모든 순열을 생성하는 함수입니다. 중요한 점은, 이 함수가 올바르게 작동하려면 시작 상태가 반드시 정렬된 상태여야 합니다. 따라서, 시작 시점에서 데이터를 정렬하고 next_permutation
을 사용하면 항상 사전순으로 다음 순열을 생성하게 되므로, 매번 올바르게 정렬된 순서를 유지합니다.
관련하여 비슷한 질문으로서, 링크를 안내해 드립니다:
- 1-A 문제 질문있습니다!
- 5-S와 next_permutation
위 글들에서도 비슷한 문제들을 다루고 있으니, 확인해 보시면 도움이 되리라 생각합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드립니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.