Java/Coding Test

[코딩테스트] 두 배열 합치기

Jane Kwon 2022. 3. 13. 22:57
반응형

 

문제

오름차순으로 정렬이 된 두 배열이 주어지면 두 배열을 오름차순으로 합쳐 출력하는 프로그램을 작성하세요.

 

입력

첫 번째 줄에 첫 번째 배열의 크기 N(1<=N<=100)이 주어집니다.

두 번째 줄에 N개의 배열 원소가 오름차순으로 주어집니다.

세 번째 줄에 두 번째 배열의 크기 M(1<=M<=100)이 주어집니다.

네 번째 줄에 M개의 배열 원소가 오름차순으로 주어집니다.

각 리스트의 원소는 int형 변수의 크기를 넘지 않습니다.

 

출력

오름차순으로 정렬된 배열을 출력합니다.

 

 

 

예시 입력

3
1 3 5
5
2 3 6 7 9

예시 출력

1 2 3 3 5 6 7 9

 

 

 

 

 

문제 풀이

 

[첫번째 풀이]

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
import java.util.stream.Collectors;

public class Main {
    public List<Integer> solution(int[] ns, int[] ms) {
        ArrayList<Integer> list = new ArrayList<>();
        for (int n : ns) list.add(n);
        for (int m : ms) list.add(m);

        return list.stream().sorted().collect(Collectors.toList());
    }

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int[] ns = new int[n];
        for (int i=0; i<n; i++) {
            ns[i] = scanner.nextInt();
        }

        int m = scanner.nextInt();
        int[] ms = new int[m];
        for (int i=0; i<m; i++) {
            ms[i] = scanner.nextInt();
        }

        Main main = new Main();
        for (Integer i : main.solution(ns, ms)) {
            System.out.print(i + " ");
        }
    }
}

(Time 382ms / Memory 33MB)

 

[두번째 풀이]

import java.util.Arrays;
import java.util.Scanner;

public class Main {
    public int[] solution(int[] ns, int[] ms) {
        int[] arr = new int[ns.length + ms.length];
        System.arraycopy(ns, 0, arr, 0, ns.length);
        System.arraycopy(ms, 0, arr, ns.length, ms.length);
        
        return Arrays.stream(arr).sorted().toArray();
    }

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int[] ns = new int[n];
        for (int i=0; i<n; i++) {
            ns[i] = scanner.nextInt();
        }

        int m = scanner.nextInt();
        int[] ms = new int[m];
        for (int i=0; i<m; i++) {
            ms[i] = scanner.nextInt();
        }

        Main main = new Main();
        for (Integer i : main.solution(ns, ms)) {
            System.out.print(i + " ");
        }
    }
}

(Time 381ms / Memory 34MB)

 

[세번째 풀이]

import java.util.Arrays;
import java.util.Scanner;

public class Main {
    public int[] solution(int[] ns, int[] ms) {
        int[] arr = new int[ns.length + ms.length];
        System.arraycopy(ns, 0, arr, 0, ns.length);
        System.arraycopy(ms, 0, arr, ns.length, ms.length);
        
        Arrays.sort(arr);
        return arr;
    }

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int[] ns = new int[n];
        for (int i=0; i<n; i++) {
            ns[i] = scanner.nextInt();
        }

        int m = scanner.nextInt();
        int[] ms = new int[m];
        for (int i=0; i<m; i++) {
            ms[i] = scanner.nextInt();
        }

        Main main = new Main();
        for (Integer i : main.solution(ns, ms)) {
            System.out.print(i + " ");
        }
    }
}

(Time 171ms / Memory 27MB)

 

 

 

- 첫번째 풀이는 ArrayList에 두 배열을 넣어서 정렬하였고, 두번째 풀이는 int 배열을 새로 만든 다음에 배열을 복사하는 기능을 이용하여 정렬하였다. 세번째 풀이는 두번째 풀이 방법과 정렬하는 방법만 다르게 풀었다.

- 결과적으론 세번째 풀이처럼 Arrays.sort() 방법을 이용해서 푸는 방식이 시간 단축과 메모리 사용에 효율적이었다.

- 풀이 영상에선 두 개의 배열을 for 문 돌면서 크기를 비교해 차례로 새로운 배열에 추가해주는 방식으로 코드를 짰던데, 왜 있는 기능을 쓰지 않고 노가다 했을까나

 

 

 

 

 

반응형