티스토리 뷰

2020/05/28 - [알고리즘 공부하기/정렬] - 알고 공부. 1) 버블 정렬

 

알고 공부. 1) 버블 정렬

버블 정렬이란 옆에 있는 값과 비교하여 더 작은 값을 반복적으로 앞으로 보내는 정렬 방법을 말한다. 구현은 가장 쉽지만 가장 비효율적인 알고리즘이다. 문제 아래의 숫자를 오름차순으로 정�

solare.tistory.com

삽입 정렬은 각 숫자를 적절한 위치에 삽입하는 방법으로 문제를 해결하게 된다.

시간 복잡도 O(N*N) 중 가장 빠른 정렬 방법이다.

 

문제는 버블 정렬의 글에 있는 문제와 동일하다.

앞에 있는 원소들이 이미 정렬이 되어있다고 가정을 한다.

이 가정이 선택과 버블 정렬보다 조금 더 효율적이지만 시간복잡도는 동일하다.

 

더보기
#include <stdio.h>

int main(void) {
	int i, j, tmp;
	int array[10] = { 10,1,5,8,7,6,4,3,9,2 };
	for (i = 0; i < 9; i++)
	{
		j = i;
		while (array[j] > array[j + 1]) {
			tmp = array[j];
			array[j] = array[j + 1];
			array[j + 1] = tmp;
			j--;
			if (j < 0)
				break;
		}
	}
	for (int i = 0; i < 10; i++)
		printf("%d ", array[i]);
	return 0;
}

 

 

 

내가 생각했던 문제 풀이 방법

- 배열 인덱스 i의 값을 가지구 배열 맨 앞부터 비교를 하면서 맞는 위치를 찾았을 때

그 위치에 값을 대입해주려고 했다. 문제가 발생했던 점은 그 뒤에 이미 정렬이 완료되었다고

가정한 인덱스가 남아있다면 이 값들은 또 계속 뒤로 밀어줘야하나? 라는 생각이 들었다.

 

간단하게 문제 해결한 것은 인덱스가 만약 5라면 5부터 0까지 내려가면서 자신의 값이 앞 인덱스의 값 보다

작을 경우에 계속 값을 스왑하면서 간다는 것이다. 그럼 아까 위에 문제점도 해결하면서 정렬도 되는 것이다.

'알고리즘 공부하기 > 정렬' 카테고리의 다른 글

알고 공부. 3) 퀵 정렬  (0) 2020.05.28
알고 공부. 1) 버블 정렬  (0) 2020.05.28
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/09   »
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
글 보관함