문제 설명
두 정수 a, d와 길이가 n인 boolean 배열 included가 주어집니다. 첫째항이 a, 공차가 d인 등차수열에서 included[i]가 i + 1항을 의미할 때, 이 등차수열의 1항부터 n항까지 included가 true인 항들만 더한 값을 return 하는 solution 함수를 작성해 주세요.

Solution 1) 내 풀이
class Solution {
public int solution(int a, int d, boolean[] included) {
int[] arr = new int[included.length];
int solution = 0;
for (int i = 0; i < arr.length; i++) {
if (i == 0) {
arr[i] = a;
} else {
arr[i] = arr[i-1] + d;
}
}
for (int i = 0; i < included.length; i++) {
if (included[i]){
solution += arr[i];
}
}
return solution;
}
}
Solution 2) 다른 사람의 풀이_Stream
import java.util.stream.IntStream;
class Solution {
public int solution(int a, int d, boolean[] included) {
return IntStream.range(0, included.length).map(idx -> included[idx]?a+(idx*d):0).sum();
}
}'연습문제 > 프로그래머스, 기초 트레이닝' 카테고리의 다른 글
| 수 조작하기2 (switch 문 사용하기) (0) | 2023.10.22 |
|---|---|
| 수 조작하기1 ( switch문) (0) | 2023.10.22 |
| 마지막 두 원소 (Arrays.copyOf) (0) | 2023.10.22 |
| 이어 붙인 수 (편한 형변환 생각해보기) (1) | 2023.10.21 |
| 코드 처리하기 (삼항 연산자의 활용) (0) | 2023.10.21 |