CodingTest

프로그래머스 - 배열 자르기(JAVA)

쩡선영 2023. 2. 2. 18:06

문제 설명


정수 배열 numbers와 정수 num1, num2가 매개변수르 주어질 때, numbers의 num1번 째 인덱스부터 num2번째 인덱스까지 자른 정수 배열을 return 하도록 solution 함수를 완성해보세요.

<제안사항>

1) 2 <= numbers의 길이 <= 30

2) 0<= numbers의 원소 <= 1,000

3) 0 <= num1 < num2 < numbers의 길이

 

 

 

내가 직접 짠 코드


class Solution {
    public int[] solution(int[] numbers, int num1, int num2) {
        int[] answer = new int [num2-num1+1];
        int cnt=0;
        for(int i=num1; i<=num2; i++){
            answer[cnt]=numbers[i];
            cnt++;
        }
        return answer;
    }
}

 

 

문제 설명


1) answer을 num2-num1+1의 길이로 배열 선언을 해줬습니다.

2) num1부터 num2까지 반복문을 돌리면서

3) answer[cnt]에 numbers[i]를 넣어주고 cnt를 하나 씩 증감시켜줬습니다

 

 

 

남이 짠 코드


import java.util.*;

class Solution {
    public int[] solution(int[] numbers, int num1, int num2) {
        return Arrays.copyOfRange(numbers, num1, num2 + 1);
    }
}

이렇게 배열을 복사 해주는 copyOfRange를 사용하면 한번에 풀 수 있습니다!

 

 

 

 

 

copyOfRange란?


copyOfRange는 자신이 복사하고자 하는 배열의 범위만 지정해서 복사를 할 수 있는 메소드인데요!

Arrays.copyOfRange(복사하고자 하는 배열, 시작위치, 배열크기); 이렇게 선언해주면 됩니다

 

비슷한 것으로 copyOf가 있는데요! 이 메소드는 범위 지정은 하지 못합니다!

Arrays.copyOf(복사할 배열, 복사할 배열의 크기); 이렇게 하면 복사가 됩니다