728x90
https://www.youtube.com/watch?v=h2_Lc8a8Ffw&list=PLFgS-xIWwNVX-zm4m6suWC9d7Ua9z7fuT&index=15
📌 정렬 알고리즘
정렬 알고리즘정의
버블 (bubble) | 데이터의 인접 요소끼리 비교하고 swap 연산을 수행하여 정렬 |
선택 (selection) | 대상에서 가장 크거나 작은 데이터를 찾아가 선택을 반복하며 정렬 |
삽입 (insertion) | 대상을 선택해 정렬된 영역에서 선택 데이터의 적절한 위치를 찾아 삽입하면서 정렬 |
퀵 (quick) | pivot 값을 선정해 해당 값을 기준으로 정렬 |
병합 (merge) | 이미 정렬된 부분 집합들을 효율적으로 병합해 전체를 정렬하는 |
기수 (radix) | 데이터의 자릿수를 바탕으로 비교해 데이터를 정렬 |
📌 버블 정렬
- 간단한 구현 가능
- 시간 복잡도가 O(n²)으로 속도가 느린 편
◾ 버블 정렬 과정
- 비교 연산이 필요한 루프 범위 설정
- 인접한 데이터 값 비교
- swap 조건에 부합하면 swap 연산 수행
- 루프 범위가 끝날 때 까지 2~3 반복
- 정렬 영역을 설정. (다음 루프 실행 시 이 영역 제외)
- 비교 대상이 없을 때 까지 1~5 반복
- 만약, 특정 루프의 전체 영역에서 swap이 한 번도 발생하지 않았다면 데이터가 모두 정렬 되었다는 뜻
728x90
'Java > Do it 알고리즘 코딩테스트 핵심이론 강의' 카테고리의 다른 글
알고리즘 코딩테스트 핵심이론 강의 - 퀵 정렬 (0) | 2023.08.09 |
---|---|
알고리즘 코딩테스트 핵심이론 강의 - 선택 정렬 (0) | 2023.08.09 |
알고리즘 코딩테스트 핵심이론 강의 - 스택과 큐 (0) | 2023.08.09 |
알고리즘 코딩테스트 핵심이론 강의 - 구간합 (0) | 2023.08.09 |
알고리즘 코딩테스트 핵심이론 강의 - 배열과 리스트 (0) | 2023.08.09 |