[문제]
두 정수 a, d와 길이가 n인 boolean 배열 included가 주어집니다. 첫째항이 a, 공차가 d인 등차수열에서 included[i]가 i + 1항을 의미할 때, 이 등차수열의 1항부터 n항까지 included가 true인 항들만 더한 값을 return 하는 solution 함수를 작성해 주세요.
a | d | included | result |
3 | 4 | [true, false, false, true, true] | 37 |
7 | 1 | [false, false, false, true, false, false, false] | 10 |
[답]
class Solution {
public int solution(int a, int d, boolean[] included) {
int answer = 0;
for(int i = 0; i < included.length; i++) {
if(included[i] == true) {
answer += a + (d * i);
}
}
return answer;
}
}
[다른사람 풀이]
import java.util.stream.IntStream;
class Solution {
public int solution(int a, int d, boolean[] included) {
//Stream 작성 (공부후, 다시 보기)
return IntStream.range(0, included.length).map(idx -> included[idx]?a+(idx*d):0).sum();
}
}
'Coding Practice > 프로그래머스 Lv.0' 카테고리의 다른 글
이어 붙인 수 (0) | 2024.01.26 |
---|---|
원소들의 곱과 합 (0) | 2024.01.26 |
코드 처리하기 (0) | 2024.01.25 |
flag에 따라 다른 값 반환하기 (0) | 2024.01.24 |
조건 문자열 (0) | 2024.01.24 |