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

TaeSeok Ma님의 프로필 이미지
TaeSeok Ma

작성한 질문수

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

2-G

2910번 질문 드립니다.

해결된 질문

작성

·

140

0

큰돌님 안녕하세요. 저는 이 문제를 map을 쓰지 않고 그냥 vector에서 find_if함수를 이용하여 풀었는데요. 제가 생각했을때에 sort한다면 입력받는 순서대로 vector에 push하게 되니까 먼저 나온것이 앞에 있어야된다는 조건을 자동적으로 처리될꺼라 생각했는데 오류가 났습니다. 그래서 stable_sort를 사용하여 결국 풀긴했는데 왜 그냥 sort는 안되는 것일까요?

 

소스코드 : http://boj.kr/84577fb3c0724cc3954dfd6ccfa2b412

답변 1

1

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

안녕하세요 ㅎㅎ

sort한다면 입력받는 순서대로 vector에 push하게 되니까 먼저 나온것이 앞에 있어야된다는 조건을 자동적으로 처리될꺼라 생각했는데 오류가 났습니다.

>> 아닙니다. sort는 그저 정렬이지, 먼저 나온 것이 앞에 있어야 한다는 조건은 충족할 수도, 충족하지 않을 수 있습니다. 다만 stable_sort는 주어진 순서가 유지가 되는 성질이 있습니다.

 

좀 더 자세히 설명하면요. 2개의 함수는 정렬 안정성(Sorting Stability)이 다릅니다.

  • sort 함수는 불안정 정렬 알고리즘을 사용합니다. 이는 같은 값을 가진 요소들의 상대적인 순서가 정렬 후에 보존되지 않을 수 있다는 것을 의미합니다.

  • stable_sort 함수는 안정 정렬 알고리즘을 사용합니다. 이는 같은 값을 가진 요소들의 상대적인 순서가 정렬 전과 동일하게 보존된다는 것을 의미합니다. 따라서, 두 요소가 비교될 때 동일하다고 간주되면, 그들의 순서는 변경되지 않습니다.

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


TaeSeok Ma님의 프로필 이미지
TaeSeok Ma

작성한 질문수

질문하기