c++의 List에서 sort 여러번 사용하면 전부 적용이 되나요?
글쓴이: yann8166 / 작성시간: 목, 2014/05/29 - 11:18오전
안녕하세요.
c++ stㅣ의 list를 사용하던중 궁금증이 생겼습니다.
회사에서 기존에 누가 짜놓은 소스를 보면
list.sort(compare_idx); // compare_idx : index 크기를 비교
list.sort(compare_time); // compare_time : 시간을 비교
이처럼 sort를 연속 두번 사용하였더군요.
의도가 idx로 먼저 1차 정렬을 하고 time으로 2차 정렬을 하려고 했던것 같은데
사실상 위와같이 사용하면 결국은 위의 정렬은 무의미하고 아래의 time순서대로 정렬 되는 것 아닌가요?
Forums:
Equivalent elements are
--
저런게 숨어있으면 재앙이죠..
std::list::sort()는 stable
std::list::sort()는 stable sort입니다.
아.. 그러네요. 잘못봤습니다.. ^^
아.. 그러네요. 잘못봤습니다.. ^^
추가적으로 생각할 수 있는 의도는 두가지가
추가적으로 생각할 수 있는 의도는 두가지가 있습니다.
1. 비교함수의 side-effect를 활용한다.
올리신 코드만으론 알 수 없지만 compare_idx나 compare_time에서 단순히 비교만 하는게 아니라 내부적으로 뭔가를 할지도 모릅니다.
2. stable sort인점을 활용한다.
std::list::sort()는 stable sort이기 때문에 인덱스로 먼저 정렬하고 시간으로 정렬하면, 같은 시간끼리는 인덱스로 정렬된 순서가 유지됩니다.
중복되는 시간에 대해서 인덱스 정렬상태를 유지하기 위한 걸 수도 있습니다.
2번일 가능성이 높아 보입니다만, 사실 그렇게 하려면 비교함수에서 시간이 같으면 인덱스를 비교하게끔 해서 한번에 정렬하는게 낫죠.
이 의도가 맞는것 같네요!
직접 테스트를 해보니 말씀하신데로 같은 시간끼리는 인덱스가 정렬된 효과가 있군요.
가르침 얻고 갑니다 ^^
댓글 달기