염딩코

백준 24060번 c++ 풀이 본문

알고리즘 PS/C++

백준 24060번 c++ 풀이

johnyeom 2023. 4. 29. 11:50

문제

오늘도 서준이는 병합 정렬 수업 조교를 하고 있다. 아빠가 수업한 내용을 학생들이 잘 이해했는지 문제를 통해서 확인해보자.

N개의 서로 다른 양의 정수가 저장된 배열 A가 있다. 병합 정렬로 배열 A를 오름차순 정렬할 경우 배열 A에 K 번째 저장되는 수를 구해서 우리 서준이를 도와주자.

크기가 N인 배열에 대한 병합 정렬 의사 코드는 다음과 같다.

merge_sort(A[p..r]) { # A[p..r]을 오름차순 정렬한다.
    if (p < r) then {
        q <- ⌊(p + r) / 2⌋;       # q는 p, r의 중간 지점
        merge_sort(A, p, q);      # 전반부 정렬
        merge_sort(A, q + 1, r);  # 후반부 정렬
        merge(A, p, q, r);        # 병합
    }
}

# A[p..q]와 A[q+1..r]을 병합하여 A[p..r]을 오름차순 정렬된 상태로 만든다.
# A[p..q]와 A[q+1..r]은 이미 오름차순으로 정렬되어 있다.
merge(A[], p, q, r) {
    i <- p; j <- q + 1; t <- 1;
    while (i ≤ q and j ≤ r) {
        if (A[i] ≤ A[j])
        then tmp[t++] <- A[i++]; # tmp[t] <- A[i]; t++; i++;
        else tmp[t++] <- A[j++]; # tmp[t] <- A[j]; t++; j++;
    }
    while (i ≤ q)  # 왼쪽 배열 부분이 남은 경우
        tmp[t++] <- A[i++];
    while (j ≤ r)  # 오른쪽 배열 부분이 남은 경우
        tmp[t++] <- A[j++];
    i <- p; t <- 1;
    while (i ≤ r)  # 결과를 A[p..r]에 저장
        A[i++] <- tmp[t++]; 
}

입력

첫째 줄에 배열 A의 크기 N(5 ≤ N ≤ 500,000), 저장 횟수 K(1 ≤ K ≤ 108)가 주어진다.

다음 줄에 서로 다른 배열 A의 원소 A1, A2, ..., AN이 주어진다. (1 ≤ Ai ≤ 109)

출력

배열 A에 K 번째 저장 되는 수를 출력한다. 저장 횟수가 K 보다 작으면 -1을 출력한다.


풀이

 

 

Merge sort는 기본적으로 Divide and Conquer 문제입니다.

Merge sortQuick sort에 대한 기본적인 내용은 아래의 글에서 확인하실 수 있습니다. 

 

2023.03.30 - [알고리즘] - Merge sort & Quick sort

 

Merge sort & Quick sort

Merge sort Implementation Divide 하나의 배열을 반으로 나눠 2개의 배열로 만든다. Conquer Subarray가 충분히 작아졌다면, 정렬시킨다. Subarray가 충분히 작지 않다면, Recursion Merge 정렬된 subarray를 합쳐서 하

yeomyeom.tistory.com

위의 코드에서

merge_sort 함수는 배열의 크기를 요소 단위까지 Divide하는 과정입니다.

merge 함수는 오름차순으로 정렬하면서 temp 배열에 값을 대입합니다. 

그렇게 정렬한 값을 arr 배열에 다시 넣을 때, inputCnt을 증가시키면서 입력받은 K값과 같을 때, 출력을 합니다.

 

'알고리즘 PS > C++' 카테고리의 다른 글

백준 4779번 c++ 풀이  (0) 2023.04.30
백준 25501번 c++ 풀이  (0) 2023.04.28
백준 27433번 c++ 풀이  (0) 2023.04.28
백준 2581번 c++ 문제 풀이  (1) 2022.02.24
백준 2501번 c++ 문제 풀이  (0) 2022.02.24