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
수정 아이콘
아 정말감사합니다.. 조금만생각해봐도되는건데 무릎을 치고갑니다

힙부분도 이해가 되네요

답변감사합니다!!
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
101345 [질문] 해외 송금 시 수수료 관련 질문입니다. [13] 로각좁4559 17/04/20 4559
101344 [질문] 스타1 프레임 드랍 현상 청학동2517 17/04/20 2517
101343 [질문] 머신러닝 용 그래픽카드 질문입니다. [4] 1llionaire2622 17/04/20 2622
101342 [질문] 신축빌라에 전세사는데 곰팡이가 피었어요. [8] 완성형폭풍저그가되자4683 17/04/20 4683
101341 [질문] 코어 운동을 여쭙고 싶습니다. [2] 회색사과2378 17/04/20 2378
101340 [질문] 포장이사를 맡길 좋은 업체나 사이트 추천 부탁드립니다. [3] 왕삼구2104 17/04/20 2104
101339 [질문] 어머니 쓰실 노트북 추천좀 부탁드릴게요 [7] 젤나가2178 17/04/20 2178
101338 [질문] cpu 온도 정상인가요? [4] Ma Lin4053 17/04/20 4053
101337 [질문] 마우스 휠이 떄로 역방향으로 되는데요... [1] lou5024 17/04/20 5024
101336 [질문] 스타1 fish서버 질문합니다. [2] kongkaka2616 17/04/20 2616
101335 [질문] 하드 인식 문제 질문드려요. [1] nELLmOtSiwA2119 17/04/20 2119
101334 [질문] 호텔 예약 어플중에 Endless Rain1535 17/04/20 1535
101333 [질문] 선알못이 대선정보질문 입니다. [2] 토폴로지1572 17/04/19 1572
101332 [질문] 대선주자들 억양 괜찮으신가요? [3] RnR2431 17/04/19 2431
101331 [질문] 새우 문의합니다. [7] 교자만두2375 17/04/19 2375
101330 [질문] 구글 환불 대행서비스 믿을만 한가요?? 미생5155 17/04/19 5155
101329 [질문] 무제한 요금제 질문드립니다. [6] Lefteye.MK21699 17/04/19 1699
101328 [질문] 핸드폰 MTP 설정하지 않고 인식 가능할까요? [1] mcmc1896 17/04/19 1896
101327 [질문] 30대 중반에 현금 7억말고 가진게 아무것도 없다면 [26] 삭제됨5752 17/04/19 5752
101326 [질문] 요즘 핸드폰값 원래 비싼가요?? [9] 우리집개2537 17/04/19 2537
101325 [질문] 조깅&산책할 때 들을만한 팟캐스트 추천 부탁드립니다. [6] 네오크로우3461 17/04/19 3461
101324 [질문] 모니터 HDMI 선 연결문제 [11] 마음의소리2389 17/04/19 2389
101323 [질문] 엑셀이나 엑세스 함수 질문드립니다 밤공기1346 17/04/19 1346
목록 이전 다음
댓글

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