문제 설명
정수 배열 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(복사할 배열, 복사할 배열의 크기); 이렇게 하면 복사가 됩니다
'CodingTest' 카테고리의 다른 글
프로그래머스 - 세균 증식 (JAVA) (0) | 2023.02.02 |
---|---|
프로그래머스 - 삼각형의 완성조건(1) (JAVA) (0) | 2023.02.02 |
프로그래머스 - 문자열 뒤집기 (JAVA) (0) | 2023.01.31 |
프로그래머스 - 나이 출력 (JAVA) (0) | 2023.01.31 |
프로그래머스 - 개미군단 (JAVA) (0) | 2023.01.27 |