• 카테고리

    질문 & 답변
  • 세부 분야

    알고리즘 · 자료구조

  • 해결 여부

    해결됨

2910번 질문 드립니다.

24.02.04 16:14 작성 조회수 87

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점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.