알고리즘 공부하기/정렬
알고 공부. 2) 삽입 정렬
루체도
2020. 5. 28. 18:47
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까지 내려가면서 자신의 값이 앞 인덱스의 값 보다
작을 경우에 계속 값을 스왑하면서 간다는 것이다. 그럼 아까 위에 문제점도 해결하면서 정렬도 되는 것이다.