Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- C#
- 방학여행
- HackerRank
- Effective C#
- 자유여행
- build
- javascript
- 알고리즘
- 해커랭크 문제풀이
- Android
- 문제풀이
- 일본음식
- 코토리
- 개발
- 책리뷰
- 책 정리
- 독후감
- 이펙티브 씨샵
- 이펙티브 C#
- 알고리즘 문제풀이
- 정렬
- 프로그래밍
- 프로그래밍도서
- IOS
- 유니티
- 빌드
- 서평
- Unity
- 독서
- 해커랭크
Archives
- Today
- Total
Console.Log
[Sort] 개선된 버블정렬 본문
1. 소개
버블정렬은 인접한 요소를 검사하여 정렬하는 방식입니다.
여기서 이미 정렬이 되어있을시 넘어가는 개선된 버블정렬을 소개하려합니다.
2. 장점 & 단점
시간복잡도는 O(n²)으로 느립니다. 하지만 코드가 단순합니다.
개선된 버블정렬은 이미 정렬되있을시 넘어갑니다.
3. 정렬 순서
< 알아두어야 할것 >
1. 이 버블정렬은 오름차순 정렬입니다.
2. 조건: 둘이 비교하여 왼쪽이 더 클경우 교환
- 이번엔 2,4,5,1,3 이라는 임의의 수를 버블정렬을 통해 정렬해보겠습니다.
2와 4부터 비교하죠
조건에 맞을때까지 돌립니다~
조건에 맞는칸 발견! 교환 ~
- 다음칸도 조건 일치! 교환!
- 이제 5는 무조건 확정이니 두고
다시 처음부터 시작합니다
여기도 조건에 맞으니 교환!
- 다시첨으로가서 바로 조건에 맞는친구 교환
정렬 완료!
4. 코드
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 | #include <stdio.h> // 개선된 버블정렬 #if 1 // bool 값을 넣어 오름차순인지 내림차순인지 확인함 // flag를 넣어 바뀔값이 없으면 그대로 나옴 void BubbleSort(int data[], int dataSize, bool isAscending) { int i, j, temp; bool flag = true; int count = 0; for (int i = 0; flag > 0; i++) { flag = false; for (j = 0; j < dataSize - (i + 1); j++) { if (isAscending ? data[j]>data[j + 1] : data[j] < data[j+1]) { flag = true; temp = data[j + 1]; data[j + 1] = data[j]; data[j] = temp; } ++count; } } printf("count: %d\n", count); } #endif int main() { int data[] = {2,4,1,3,5 }; int dataSize = sizeof(data) / sizeof(data[0]); int i; // QuickSort(data,dataSize); BubbleSort(data, dataSize, true); for (int i = 0; i < dataSize; i++) { printf("%d ", data[i]); }printf("\n"); return 0; } | cs |
'프로그래밍 > 정렬' 카테고리의 다른 글
[Sort]삽입정렬 (0) | 2016.04.17 |
---|---|
[Sort] 퀵 졍렬 (0) | 2015.09.29 |