배열 자르기
https://school.programmers.co.kr/learn/courses/30/lessons/120833
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
1) 문제
numbers의 num1번 째 인덱스부터 num2번째 인덱스까지 자른 정수 배열을 return 하도록 solution 함수를 완성해보세요.
2 ≤ numbers의 길이 ≤ 30
0 ≤ numbers의 원소 ≤ 1,000
0 ≤num1 < num2 < numbers의 길이
2) 예시
numbers | num1 | num2 | result |
---|---|---|---|
[1, 2, 3, 4, 5] | 1 | 3 | [2, 3, 4] |
[1, 3, 5] | 1 | 2 | [3, 5] |
입출력 예 #1
[1, 2, 3, 4, 5]의 1번째 인덱스 2부터 3번째 인덱스 4 까지 자른 [2, 3, 4]를 return 합니다.
입출력 예 #2
[1, 3, 5]의 1번째 인덱스 3부터 2번째 인덱스 5까지 자른 [3, 5]를 return 합니다.
3) 풀이
1. 클래스 선언을 해줍니다
● class Solution {
클래스명은 대문자로 시작해야하고, 정답이라는 의미로 Solution이라는 단어를 사용하였습니다.
2. 메소드 선언을 해줍니다.
● public int[] solution(int[] numbers, int num1, int num2){
정수배열 numbers, 정수 num1, num2를 매개변수로 사용하는 solution 메소드를 선언해줍니다.
메소드의 결과값인 solution은 정수배열로 나오므로, 데이터 타입을 int[]로 해줍니다.
3. 제한사항을 만족시키기위한 검사를 시행하고, 만족하지 않을 경우 예외처리해줍니다.
● // 배열길이 제한 검사
if (numbers.length < 2 || numbers.length > 30) {
throw new IllegalArgumentException("numbers 배열 길이는 2 이상 30 이하여야합니다");
}
// 원소 크기 제한 검사
for (int i = 0; i < numbers.length; i++) {
if (numbers[i] < 0 || numbers[i] > 1000) {
throw new IllegalArgumentException("numbers의 원소는 0 이상 1000 이하여야합니다");
}
}
// num1 num2 numbers 길이 제한 검사
if (num1 < 0 || num1 >= num2 || num2 >= numbers.length) {
throw new IllegalArgumentException("num1, num2, numbers 길이 제한사항을 확인하세요");
}
4. 먼저 잘라낸 정수배열(newArray)을 생성해줍니다.
newArray의 배열길이는 num2에서 num1을 빼고 1을 더해준 값이 됩니다.
(처음에 저는 잘라내고 남은 부분이 새로운 배열이 되는 줄 알았는데, 잘라내서 떼어낸 그것이 새로운 배열이 되는 것이었습니다.)
● int[] newArray = new int[num2 - num1 + 1];
int index = 0;
for (int i = num1; i <= num2; i++) {
newArray[index++] = numbers[i];
}
return newArray;
}
그리고 새로운 newArray 배열의 인덱스값을 0으로 초기화해주고,
newArray의 index 0번부터 시작해서 index++을 통해 1씩 증가할때마다 새로운 원소값으로 numbers[i]를 추가해줍니다.
이 때 numbers[i]는 for문을 통해 1씩 증가하되, num1에서 시작하여 num2까지의 값까지만 증가합니다.
(numbers[num1] ~ numbers[num2]까지가 newArray의 원소가 된다는 뜻입니다)
이렇게 새로 생성한 newArray를 반환해줍니다.
4) 코드
class Solution {
public int[] solution(int[] numbers, int num1, int num2) {
// 배열길이 제한 검사
if (numbers.length < 2 || numbers.length > 30) {
throw new IllegalArgumentException("numbers 배열 길이는 2 이상 30 이하여야합니다");
}
// 원소 크기 제한 검사
for (int i = 0; i < numbers.length; i++) {
if (numbers[i] < 0 || numbers[i] > 1000) {
throw new IllegalArgumentException("numbers의 원소는 0 이상 1000 이하여야합니다");
}
}
// num1 num2 numbers 길이 제한 검사
if (num1 < 0 || num1 >= num2 || num2 >= numbers.length) {
throw new IllegalArgumentException("num1, num2, numbers 길이 제한사항을 확인하세요");
}
int[] newArray = new int[num2 - num1 + 1];
int index = 0;
for (int i = num1; i <= num2; i++) {
newArray[index++] = numbers[i];
}
return newArray;
}
}
'Programmers Coding Test > Java' 카테고리의 다른 글
[프로그래머스 120898] Java - 코딩테스트 입문 / 편지 (0) | 2024.01.26 |
---|---|
[프로그래머스 120908] Java - 코딩테스트 입문 / 문자열안에 문자열 (1) | 2024.01.26 |
[프로그래머스 120847] Java - 코딩테스트 입문 / 최댓값 만들기(1) (1) | 2024.01.25 |
[프로그래머스 120817] Java - 코딩테스트 입문 / 배열의 평균값 (0) | 2024.01.23 |
[프로그래머스 120831] Java - 코딩테스트 입문 / 짝수의 합 (1) | 2024.01.23 |