[알고리즘 문제풀이] 수 정렬하기 2

황인권·2023년 3월 18일
0

알고리즘 문제풀이

목록 보기
17/81

문제 제목 : 수 정렬하기 2

문제 난이도 : 하

문제 유형 : 정렬

https://www.acmicpc.net/problem/2751
시간 제한 : 2초
메모리 제한 : 256MB

문제풀이 아이디어

< 소스코드 >

# Merge Sort -> Dived & conquer
def merge_sort(array):
    if len(array) <= 1:
        return array
    mid = len(array) // 2
    left = merge_sort(array[:mid])
    right = merge_sort(array[mid:])
    i, j, k = 0, 0, 0
    while i < len(left) and j < len(right):
        if left[i] <= right[j]:
            array[k] = left[i]
            i += 1
        else:
            array[k] = right[j]
            j += 1
        k += 1
    if i == len(left):
        while j < len(right):
            array[k] = right[j]
            j += 1
            k += 1
    elif j == len(right):
        while i < len(left):
            array[k] = left[i]
            i += 1
            k += 1
    return array

n = int(input())
array = []
for _ in range(n):
    array.append(int(input()))

array = merge_sort(array)
for data in array:
    print(data)
profile
inkwon Hwang

0개의 댓글