클래스명은 대문자로 시작해야하고, 정답이라는 의미로 Solution이라는 단어를 사용하였습니다.
2. 메소드 선언을 해줍니다.
● public int[] solution(int[] numbers) {
정수배열 numbers를 매개변수로 사용하는 solution 메소드를 선언해줍니다.
메소드의 결과값인 solution은 정수배열로 나오므로, 데이터 타입을 int[]로 해줍니다.
3. numbers의 두배 값이 담기는 answer 배열을 선언해줍니다.
배열의 크기는 numbers.length값과 동일하게 할당해줍니다.
● int[] answer = new int[numbers.length];
4. 배열의 길이에 대한 제한사항을 확인하고, 만족하지 않는다면 예외처리합니다.
● if(1> numbers.length || numbers.length > 1000){ throw new IllegalArgumentException("배열 길이는 1 이상 1000 이하여야합니다"); }
5. 먼저 정수 index를 선언해줍니다. 그 index는 새로운 배열 answer의 인덱스로 사용될 예정입니다.
제한사항에 만족할 경우, for문을 통해 numbers 배열을 순회하면서
numbers 배열의 i번째 인덱스일때 그 값을 2배 해주며, answer 배열의 index 값 0부터 값을 할당해줍니다.
numbers의 i도 0부터 시작이고, answer 배열의 index도 0부터 시작해서 1씩 증가하니 같이 계속 numbers배열의 길이까지 증가할 것입니다.
이렇게 모든 순회가 끝난 값인 answer을 반환해줍니다.
● int index = 0;
for(int i = 0; i < array.length; i++){ if(1<= array[i] && array[i]<=200 && array[i] > height){ result++; }
} return result; } }
4) 코드
class Solution {
public int[] solution(int[] numbers) {
int[] answer = new int[numbers.length];
if(1> numbers.length || numbers.length > 1000){
throw new IllegalArgumentException("배열 길이는 1 이상 1000 이하여야합니다");
}
int index = 0;
for(int i=0; i < numbers.length; i++){
if(-10000> numbers[i] || numbers[i] > 10000){
throw new IllegalArgumentException("배열의 원소 크기 제한을 확인하세요");
}
answer[index++] = numbers[i] * 2;
}
return answer;
}
}