강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

김현우님의 프로필 이미지
김현우

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

1-A

순열로 풀시 정렬이 안되는 경우도 있는거 아닌가요??

작성

·

27

0

정렬이 되지 않는 경우도 있을거 같은데 왜 문제가 풀리는지 잘 이해가 안갑니다. 처음부터 7까지 짤라서 다시 sort 시키는 건 필요없나요?

답변 2

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 ㅎㅎ

충분히 헷갈리실 수 있는 부분인데요.

  1. 순열로 하기 전에 (next_permutation) -> 먼저 sort()를 진행하기 때문에 정렬이 된 상태에서 진행이 됩니다.

 

  1. 예를 들어 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

위 글들에서도 비슷한 문제들을 다루고 있으니, 확인해 보시면 도움이 되리라 생각합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드립니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

김현우님의 프로필 이미지
김현우

작성한 질문수

질문하기