728x90
320x100
📌 정렬 알고리즘 종류
정렬 알고리즘 | 정의 |
버블 (bubble) | 데이터의 인접 요소끼리 비교하고, swap 연산을 수행하며 정렬하는 방식 |
선택 (selection) | 대상에서 가장 크거나 작은 데이터를 찾아가 선택을 반복하면서 정렬하는 방식 |
삽입 (insertion) | 대상을 선택해 정렬된 영역에서 선택 데이터의 적절한 위치를 찾아 삽입하면서 정렬하는 방식 |
퀵 (quick) | pivot 값을 선정해 해당 값을 기준으로 정렬하는 방식 |
병합 (merge) | 이미 정렬된 부분 집합들을 효율적으로 병합해 전체를 정렬하는 방식 |
기수 (radix) | 데이터의 자릿수를 바탕으로 비교해 데이터를 정렬하는 방식 |
📌 버블 정렬이란?
- 두 인접한 데이터의 크기를 비교해서 정렬하는 방법
- 인접한 2개의 데이터를 비교하여 크기가 순서대로 되어 있지 않으면 서로 교환하는 방식
- 시간 복잡도는 O(n^2)로 느린편..
- 루프를 돌면서 인접한 데이터 간의 swap 연산으로 정렬
- 선택 정렬과 기본 개념이 유사함
📌 버블 정렬 과정
- 비교 연산이 필요한 루프 범위를 설정
- 인접한 데이터 값을 비교
- swap 조건에 부합하면 swap 연산을 수행
- 루프 범위가 끝날 때까지 2번 3번 반복
- 정렬 영역을 설정 (다음 루프를 실행할 때는 이 영역 제외)
- 비교 대상이 없을 때까지 1번 ~ 5번 반복
- swap이 더이상 발생하지 않는다면 모두 정렬되었다는 뜻이므로 프로세스 종료
✅ 다음 게시글에서 예제 문제로 더 자세히 이해해보도록 하겠습니다!
[JAVA][Baekjoon] 2750번 수 정렬하기
https://www.acmicpc.net/problem/2750📌 접근 방식여러 정렬 방법 중 버블 정렬을 이용하여 풀었습니다. [알고리즘] 버블 정렬(Bubble Sort)이란?📌 정렬 알고리즘 종류정렬 알고리즘정의버블 (bubble)데이터
nyeroni.tistory.com
![](https://t1.daumcdn.net/keditor/emoticon/friends1/large/010.gif)
Reference
[Algorithm/Java] 버블정렬 (bubble sort)
버블정렬 (bubble sort) 버블정렬은 인접한 두 데이터의 크기를 비교해 두 데이터를 서로 바꿔가며 정렬하는 방법이다. 간단히 구현할 순 있지만, 시간복잡도는 O(n^2)로 다른 정렬 알고리즘보다 속
innovation123.tistory.com
728x90
반응형
'CS > 알고리즘' 카테고리의 다른 글
[알고리즘] 기수 정렬(Radix Sort)이란? (0) | 2025.01.03 |
---|---|
[알고리즘] 병합 정렬(Merge Sort)이란? (0) | 2025.01.03 |
[알고리즘] 퀵 정렬(Quick Sort)이란? (1) | 2025.01.02 |
[알고리즘] 삽입 정렬(Insertion Sort)이란? (0) | 2025.01.02 |
[알고리즘] 선택 정렬(Selectio Sort)이란? (2) | 2025.01.02 |