반응형
시간 제한 | 메모리 제한 | 제출 | 정답 | 맞은 사람 | 정답 비율 |
---|---|---|---|---|---|
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();
}
}
반응형
'알고리즘 > [ Baekjoon ]' 카테고리의 다른 글
[ BOJ ][JAVA][12896] 스크루지 민호 (0) | 2021.05.04 |
---|---|
[ BOJ ][JAVA][11729] 하노이 탑 이동 순서 (0) | 2021.05.04 |
[ BOJ ][JAVA][11726] 2xn 타일링 (0) | 2021.05.04 |
[ BOJ ][JAVA][1753] 최단경로 (0) | 2021.05.04 |
[ BOJ ][JAVA][1516] 게임 개발 (0) | 2021.05.04 |