구현이 쉽다는 장점이 있는 알고리즘 이지만 그만큼 제일 비효율적인 알고리즘이다. 붙어 있는 두 숫자를 비교해서 작은걸 앞으로 보내고 큰 것을 뒤로 보낸다. 이렇게 하면 제일 큰 수가 제일 뒤로 가기 때문에 loop을 한번 돌 때마다 마지막 자리에서 빼기 1을 한 인덱스까지만 정렬을 실행 해주면 된다. 제일 큰 수를 오른쪽에서 하나씩 비교하면서 끌어 올려 오른쪽부터 정렬 해준다고 생각하면 편하다.
#include <iostream>
using namespace std;
int main(){
int i, j, temp;
int array[10]={10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
for (i=0; i<10; i++){
for(j = 0; j<9-i; j++){
if(array[j]>array[j+1]){
temp = array[j];
array[j]=array[j+1];
array[j+1]=temp;
}
}
}
for(i=0; i<10; i++){
cout<<array[i]<<" ";
}
}
O(N^2)