반응형
250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- Pass By Value
- 코딩테스트
- Homebrew
- fastapi
- MSA
- DB
- 렌탈스튜디오창업
- union
- 의사결정나무모형
- 맥북환경설정
- 컴퓨터공학학사취득
- 계정계
- oracleapex
- 채널계
- 개인프로필스튜디오창업
- 오라클
- 코어뱅킹
- 학점은행제무료강의
- it자격증
- jdk17
- 은행IT
- 맥북
- 프로그래머스
- jdk
- 디렉토리계층구조
- 맥북셋팅
- 학점은행제
- python
- 모놀리식
- SQL
Archives
- Today
- Total
개발머해니
[파이썬] 퀵정렬 (3) 퀵 정렬 더 멋있게 구현하기 - 분할정복 ★ 본문
728x90
반응형
실습 설명
이전 과제에서 quicksort 함수를 작성했습니다.
# 테스트 코드
test_list = [9, 5, 1, 5, 2, 8, 2, 7, 1, 3, 6, 2, 4, 7, 10, 11, 4, 6]
quicksort(test_list, 0, len(test_list) - 1)
print(test_list)
그런데 quicksort 함수에 필수로 start와 end 파라미터를 넘겨줘야 한다는 게 조금 거슬리네요. 테스트를 할 때 만큼은 아래처럼 깔끔하게 작성하고 싶은데요.
# 테스트 코드
test_list = [9, 5, 1, 5, 2, 8, 2, 7, 1, 3, 6, 2, 4, 7, 10, 11, 4, 6]
quicksort(test_list) # start, end 파라미터 없이 호출
print(test_list)
어떻게 할 수 있을까요?
실습 결과
# 두 요소의 위치를 바꿔주는 helper function
def swap_elements(my_list, index1, index2):
temp = my_list[index1]
my_list[index1] = my_list[index2]
my_list[index2] = temp
# 퀵 정렬에서 사용되는 partition 함수
def partition(my_list, start, end):
# 리스트 값 확인과 기준점 이하 값들의 위치 확인을 위한 변수 정의
i = start
b = start
p = end
# 범위안의 모든 값들을 볼 때까지 반복문을 돌린다
while i < p:
# i 인덱스의 값이 기준점보다 작으면 i와 b 인덱스에 있는 값들을 교환하고 b를 1 증가 시킨다
if my_list[i] <= my_list[p]:
swap_elements(my_list, i, b)
b += 1
i += 1
# b와 기준점인 p 인덱스에 있는 값들을 바꿔준다
swap_elements(my_list, b, p)
p = b
#pivot의 최종 인덱스를 리턴해 준다
return p
# 퀵 정렬
def quicksort(my_list, start=0, end=None):
if end == None:
end = len(my_list) - 1
# base case
if end - start < 1:
return
# my_list를 두 부분으로 나누어주고,
# partition 이후 pivot의 인덱스를 리턴받는다
pivot = partition(my_list, start, end)
# pivot의 왼쪽 부분 정렬
quicksort(my_list, start, pivot - 1)
# pivot의 오른쪽 부분 정렬
quicksort(my_list, pivot + 1, end)
# 테스트 1
list1 = [1, 3, 5, 7, 9, 11, 13, 11]
quicksort(list1) # start, end 파라미터 없이 호출
print(list1)
# 테스트 2
list2 = [28, 13, 9, 30, 1, 48, 5, 7, 15]
quicksort(list2) # start, end 파라미터 없이 호출
print(list2)
# 테스트 3
list3 = [2, 5, 6, 7, 1, 2, 4, 7, 10, 11, 4, 15, 13, 1, 6, 4]
quicksort(list3) # start, end 파라미터 없이 호출
print(list3)
[1, 3, 5, 7, 9, 11, 11, 13]
[1, 5, 7, 9, 13, 15, 28, 30, 48]
[1, 1, 2, 2, 4, 4, 4, 5, 6, 6, 7, 7, 10, 11, 13, 15]
힌트 1
파이썬 함수의 옵셔널 파라미터(Optional Parameter) 기억하시나요?
def func1(p1, p2, p3=0, p4=None):
print(p1, p2, p3, p4)
func1(2, 3, 5, 7)
func1(11, 13) # p3와 p4을 따로 설정하지 않았으니 기본값인 0과 None이 지정됨
2 3 5 7
11 13 0 None
728x90
반응형
'알고리즘' 카테고리의 다른 글
[파이썬] 피보나치 수열 (2) tabulation로 구현 - 다이나믹 프로그래밍 ★ (0) | 2023.09.18 |
---|---|
[파이썬] 피보나치 수열 (1) memoization로 구현 - 다이나믹 프로그래밍 ★ (0) | 2023.09.18 |
[파이썬] 퀵정렬 (2) quicksort 함수 - 분할정복 ★ (0) | 2023.09.17 |
[파이썬] 퀵정렬 (1) partition 함수 - 분할정복 ★ (0) | 2023.09.17 |
[파이썬] 합병정렬 (2) merge_sort 함수 - 분할정복 ★ (0) | 2023.09.16 |