머쓱이는 학교에서 키 순으로 줄을 설 때 몇 번째로 서야 하는지 궁금해졌습니다. 머쓱이네 반 친구들의 키가 담긴 정수 배열 array와 머쓱이의 키 height가 매개변수로 주어질 때, 머쓱이보다 키 큰 사람 수를 return 하도록 solution 함수를 완성해보세요.
제한사항 1 ≤ array의 길이 ≤ 100 1 ≤ height ≤ 200 1 ≤ array의 원소 ≤ 200
2) 예시
Result Table
array
height
result
[149, 180, 192, 170]
167
3
[180, 120, 140]
190
0
입출력 예 #1 149, 180, 192, 170 중 머쓱이보다 키가 큰 사람은 180, 192, 170으로 세 명입니다.
입출력 예 #2 180, 120, 140 중 190보다 큰 수는 없으므로 0명입니다.
3) 풀이
1. 클래스 선언을 해줍니다
● class Solution {
클래스명은 대문자로 시작해야하고, 정답이라는 의미로 Solution이라는 단어를 사용하였습니다.
2. 메소드 선언을 해줍니다.
● public int solution(int[] array, int height) {
정수배열 array(머쓱이네 반 친구들의 키)와 정수 height(머쓱이)를 매개변수로 사용하는 solution 메소드를 선언해줍니다.
메소드의 결과값인 solution은 정수(머쓱이보다 키 큰 사람의 수)로 나오므로, 데이터 타입을 int로 해줍니다.
3. 머쓱이보다 키가 큰 사람의 수를 result로 선언하고 초기화해줍니다.
● int result = 0;
4. 배열의 길이 그리고 머쓱이의 키에 대한 제한사항을 확인하고, 만족하지 않는다면 예외처리합니다.
● if(1> array.length || array.length > 100){ throw new IllegalArgumentException("배열 길이는 1 이상 100 이하여야합니다"); }
if(1> height|| height > 200){ throw new IllegalArgumentException("머쓱이의 키는 1 이상 200 이하여야합니다."); }
5. for문을 통해 머쓱이의 반 학생들 키 배열을 순회하면서, 머쓱이의 키보다 큰 사람을 찾습니다.
이때 제한사항으로 배열의 원소크기 제한도 동시에 확인합니다.
모든 제한사항에 만족하고, 머쓱이의 키보다 크다면 result 값이 1 증가합니다.
이렇게 모든 순회가 끝난 값인 result를 반환해줍니다.
● 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[] array, int height){
int result = 0;
//제한사항 확인
if(1> array.length || array.length > 100){
throw new IllegalArgumentException("배열 길이는 1 이상 100 이하여야합니다");
}
if(1> height|| height > 200){
throw new IllegalArgumentException("머쓱이의 키는 1 이상 200 이하여야합니다.");
}
for(int i = 0; i < array.length; i++){
if(1<= array[i] && array[i]<=200 && array[i] > height){
result++;
}
}
return result;
}
}