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

힙부분도 이해가 되네요

답변감사합니다!!
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
101508 [질문] 미니빔 프로젝터 사양 제원 비교 질문드립니다. [4] BessaR3a3823 17/04/23 3823
101507 [질문] 미국인 초딩 조카들에게 줄 선물 추천 부탁드립니다 [9] bellhorn2730 17/04/23 2730
101506 [질문] 당뇨 관련 서적 추천부탁드립니다... [4] 프로취미러2204 17/04/23 2204
101505 [질문] 몸이 아파와서 우울해질 때 뭘 해야 할지 모르겠습니다. [7] 언어물리2448 17/04/23 2448
101504 [질문] 인터넷 관련 질문 입니다. 호박때리기1693 17/04/23 1693
101503 [질문] 아는 동생이 판다는 중고컴퓨터를 사야할까요?? [28] 모어모어4204 17/04/23 4204
101502 [질문] 커제 vs 중국산 알파고 대결 캐터필러2525 17/04/23 2525
101501 [질문] 어제 롤챔스 결승 재밌었나요? [20] 반전여친3729 17/04/23 3729
101499 [질문] .CPU 질문 있습니다. [10] 시야2643 17/04/23 2643
101498 [질문] 키보드가 안눌릴때가 있습니다 opxdwwnoaqewu2257 17/04/23 2257
101497 [질문] 리신이 한타 좋은 챔프인가요? [18] 딴딴4988 17/04/23 4988
101496 [질문] 커세어 키보드 RGB계열 프로파일 적용하는 방법아는분 계시나요 초갈3483 17/04/23 3483
101495 [질문] 손목,팔목 물리치료용 저주파 치료기 추천부탁드려요 [1] Rebirth3202 17/04/23 3202
101494 [질문] 태그호이어 시계 질문입니다. [6] 1llionaire2734 17/04/23 2734
101493 [질문] 대리운전 기사가 수배범이라고 경찰에 잡혀갔는데.. [9] 이혜리4289 17/04/23 4289
101492 [질문] 윈도우10정품인증 질문입니다. [1] 두부과자3791 17/04/23 3791
101491 [질문] 이거 혹시 무고죄로 사이버 수사대에 신고가능한가요??? [7] 춥하춥하3586 17/04/23 3586
101489 [질문] 요런옷이 정확히 명칭이 있을까요? [2] 2693 17/04/23 2693
101488 [질문] 배넷 방제 검색이 안되는 이유가 뭔가요? 참글1458 17/04/23 1458
101487 [질문] 신도림에서 폰 구매에 대하여 질문드립니다~ [6] 수학고3522 17/04/22 3522
101486 [질문] 오늘 LCK 결승의 픽밴 싸움, 어떻게 보시나요? [25] SkinnerRules3639 17/04/22 3639
101485 [질문] 노트북 램 6기가(4+2) 의미가 있나요? [4] WhiteBerry4561 17/04/22 4561
101484 [질문] 김훈의 기사 [6] 티타늄2046 17/04/22 2046
목록 이전 다음
댓글

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