PGR21.com
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다.
통합 규정을 준수해 주십시오. (2015.12.25.)
Date 2017/03/19 19:38:47
Name 무민
Subject [질문] [전산지식] stable sort의 장점은 뭔가요?
전산 공부하다가 궁금한점이 있어서 올립니다.


stable , unstable sort의 개념은 알겠습니다만은

: (같은 키값을 가지는 2개의 데이터를 정렬 하면, 그 순서가 뒤바뀌지 않을때, stable sort라 한다.)

stable ,unstable 나누는 이유가 뭔가요?

보기에는 stable이 더 효율적인건 같은데 ( 불필요한 교환? 을 하지 않으니)

그 외에는 다른 장점이 있을까요?





+ 아 그리고 heap sort가 전형적인 unstable sort라 하는데  힙소트는 bst써서 키값이 중복되면 안되지 않나요? (상관없는지.. 제가 잘못알고있는거라면 정정해주세요..)

통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
17/03/19 21:13
수정 아이콘
조금 복잡한 정렬 방법들을 빼고 일반론으로 이야기하자면, stable 정렬에 해당하는 일반적인 정렬 방법은 머지, 삽입, 버블 정렬입니다. 이들은 동일 키 값에 대한 순서를 보장하지만, 메모리가 더 필요하거나(머지), 연산량을 더 많이 소모(삽입, 버블=O(n^2)) 합니다. 그런데 굳이 그러한 순서를 상관하지 않는다면 그냥 평균적으로 메모리 덜 먹고 성능이 좋은 알고리즘(예: 퀵, 힙 정렬)을 그냥 사용할 수 있습니다. 글에서는 불필요한 교환을 하지 않아서 효율적일 것 같다고 하셨지만, 순서를 보장하기 위하여 나머지 부분이 더 많이 교환되어야하는 경우(삽입, 버블 정렬)가 많습니다. 쉽게 이해하려면 그냥 순서를 보장하기 위한 제약이 걸려있다고 생각하면 조금 더 이해하기 쉬울겁니다.
stable과 unstable을 나누는 이유는 같은 키 값에 대하여 항상 같은 정렬 결과를 보여주고자 한다면 stable 정렬을 해야 합니다. 웹페이지에서 특정 데이터가 정렬된 결과를 항상 동일하게 보여줘야 한다고 할 때 unstable 정렬은 보여주는 데이터와 연관 없는 데이터가 추가되어도 웹페이지를 새로고침하면 순서가 계속 바뀔 수 있기 때문에 사용자 경험이 안 좋다고 느낄 수 있겠죠. 이러한것을 피하기 위하여 정렬할 때 그냥 unique한 또는 최대한 unique한 키 값으로 정렬하는 경우가 많습니다(예: 게시판 글번호, 시간 등). 이러면 굳이 stable, unstable을 구분할 필요가 없어지겠죠.
+ 힙정렬은 BST가 아니고 힙을 쓰기 때문에 키 값 중복 가능합니다. 힙과 BST는 다릅니다. (예: Min힙=모든 부모가 자식보다 작거나 같음, BST=모든 좌측 자식은 부모보다 작고 모든 우측 자식은 부모보다 큼)
참고로 읽을거리: https://en.wikipedia.org/wiki/Sorting_algorithm#Stability
17/03/19 22:19
수정 아이콘
아 정말감사합니다.. 조금만생각해봐도되는건데 무릎을 치고갑니다

힙부분도 이해가 되네요

답변감사합니다!!
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
99885 [질문] 이정도 컴퓨터본체면 얼마할까요?? [10] 모어모어3228 17/03/23 3228
99884 [질문] 그래픽카드 질문입니다 [11] 이워비1942 17/03/23 1942
99883 [질문] pc견적 고수님들 검토한번 부탁드려요 [10] 뽕뽕이2561 17/03/23 2561
99882 [질문] 주식 반대매매일 관련 질문 드립니다. [3] 칼퇴추구자2825 17/03/23 2825
99881 [질문] 양말 어디서 사시나요? [9] 포도사과8814 17/03/23 8814
99879 [질문] 동해쪽 한적한 해변 추천해주세요 [7] 블루데이3228 17/03/23 3228
99878 [질문] 중고나라 사기꾼을 잡았습니다!!! [23] cs6885 17/03/23 6885
99877 [질문] 원피스에 나오는 초파 피규어 질문입니다. [7] 미완2323 17/03/23 2323
99876 [질문] [섀도우버스] 패가 잘 풀렸을 때 최강덱은? [5] 블랙홀클러스터2191 17/03/23 2191
99875 [질문] 핸드폰 번호 이동시 폰 요금 관련 질문 드립니다. [4] 황정민2860 17/03/23 2860
99874 [질문] 텔레그램(telegram)설정 관련 질문 입니다. fomo2647 17/03/23 2647
99873 [질문] [컴퓨터] 제 현재 사양에서 체감상(?) 성능향상을 느끼려면 어느정도 업글해야될까요 [16] 꾼챱챱3119 17/03/23 3119
99872 [질문] 본체만 3~40만원으로 이 정도 사양을 맞출수 있을까요?? [16] 원스4398 17/03/23 4398
99870 [질문] 소설책좀 추천해주세요. [8] SuiteMan2501 17/03/23 2501
99869 [질문] Window8.1K path 기본값이 뭔지좀 알려주세요.. [1] 일정2251 17/03/23 2251
99868 [질문] 제주도 액티비티 추천 좀 부탁드려요..! [2] 속보4179 17/03/23 4179
99867 [질문] 원두 그라인더 추천 부탁드립니다 [10] 삭제됨4214 17/03/23 4214
99866 [질문] [lol] 롤 올스타전 멤버를 뽑는다면 맥스가 뽑힐까요?? [12] 손나은x배주현2067 17/03/23 2067
99865 [질문] 세월호 수습 관련 질문입니다. [7] 삭제됨2227 17/03/23 2227
99864 [질문] 이사하면서 의자를 새로 사려는데 추천부탁드립니다. [3] johann2905 17/03/23 2905
99862 [질문] 한국여행때 소지품관련 질문드립니다. [3] 삭제됨2412 17/03/23 2412
99860 [질문] 교통사고가났어요 조언부탁드립니다 [6] Dawn3136 17/03/23 3136
99859 [질문] 아프리카 bj 로이조의 인기비결이 뭔가요?? [8] Paul Pogba4452 17/03/23 4452
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로