알고리즘/[ Baekjoon ]

[ BOJ ][JAVA][11728] 배열 합치기

kim.svadoz 2021. 5. 4. 21:47
반응형

www.acmicpc.net/problem/11728

 

11728번: 배열 합치기

첫째 줄에 배열 A의 크기 N, 배열 B의 크기 M이 주어진다. (1 ≤ N, M ≤ 1,000,000) 둘째 줄에는 배열 A의 내용이, 셋째 줄에는 배열 B의 내용이 주어진다. 배열에 들어있는 수는 절댓값이 109보다 작거

www.acmicpc.net

시간 제한 메모리 제한 제출 정답 맞은 사람 정답 비율
1.5 초 256 MB 15502 6892 4501 44.227%

문제

정렬되어있는 두 배열 A와 B가 주어진다. 두 배열을 합친 다음 정렬해서 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 배열 A의 크기 N, 배열 B의 크기 M이 주어진다. (1 ≤ N, M ≤ 1,000,000)

둘째 줄에는 배열 A의 내용이, 셋째 줄에는 배열 B의 내용이 주어진다. 배열에 들어있는 수는 절댓값이 109보다 작거나 같은 정수이다.

출력

첫째 줄에 두 배열을 합친 후 정렬한 결과를 출력한다.

예제 입력 1

2 2
3 5
2 9

예제 출력 1

2 3 5 9

예제 입력 2

2 1
4 7
1

예제 출력 2

1 4 7

예제 입력 3

4 3
2 3 5 9
1 4 7

예제 출력 3

1 2 3 4 5 7 9

코드

import java.io.*;
import java.util.*;

/*
MERGE - SORT
2 2
3 5
2 9
*/
public class p11728 {
    static int n, m, a[], b[], ms[];
    static BufferedReader br;
    static BufferedWriter bw;
    static StringTokenizer st;
    static StringBuilder sb;
    public static void main(String[] args) throws IOException {
        br = new BufferedReader(new InputStreamReader(System.in));
        bw = new BufferedWriter(new OutputStreamWriter(System.out));
        st = new StringTokenizer(br.readLine());
        sb = new StringBuilder();
        n = Integer.parseInt(st.nextToken());
        m = Integer.parseInt(st.nextToken());
        a = new int[n];
        b = new int[m];
        ms = new int[n + m];

        st = new StringTokenizer(br.readLine());
        for (int i = 0; i < n; ++i) {
            a[i] = Integer.parseInt(st.nextToken());
        }
        Arrays.sort(a);

        st = new StringTokenizer(br.readLine());
        for (int i = 0; i < m; ++i) {
            b[i] = Integer.parseInt(st.nextToken());
        }
        Arrays.sort(b);

        for (int i = 0; i < n; ++i) {
            ms[i] = a[i];
        }
        for (int i = n; i < n + m; ++i) {
            ms[i] = b[i - n];
        }
        Arrays.sort(ms);
        for (int x : ms) {
            bw.write(x+" ");
        }

        bw.flush();
        bw.close();

    }
}
반응형