목차
📢 문제 출처
⏰ 문제 설명
- 양의 정수 n이 매개변수로 주어질 때, n이 홀수라면 n 이하의 홀수인 모든 양의 정수의 합을 return 하고
- n이 짝수라면 n 이하의 짝수인 모든 양의 정수의 제곱의 합을 return 하는 solution 함수를 작성해 주세요.
⏰ 입출력 예시
- 입출력 예 #1
- (1) 예제 1번의 n은 7로 홀수입니다. 7 이하의 모든 양의 홀수는 1, 3, 5, 7이고
- (2) 이들의 합인 1 + 3 + 5 + 7 = 16을 return 합니다.
- 입출력 예 #2
- (1) 예제 2번의 n은 10으로 짝수입니다. 10 이하의 모든 양의 짝수는 2, 4, 6, 8, 10이고
- (2) 이들의 제곱의 합인 22 + 42 + 62 + 82 + 102 = 4 + 16 + 36 + 64 + 100 = 220을 return 합니다.
⏰ 풀이
class Solution {
public int solution(int n) {
int answer = 0;
if (n%2==0) //짝수
{
for (int i = 0; i <= n; i++) {
if(i%2==0){
answer += (int)Math.pow(i,2);
}
}
}
else //홀수
{
for (int i = 0; i <= n; i++) {
if(i%2 ==1){
answer +=i;
}
}
}
return answer;
}
}
- n의 값이 짝수인 경우에는 제곱수로 계산, 홀수인 경우에는 홀수 합의 계산이다.
- 1차로, n의 값의 짝수인지, 홀수인지 조건식을 구해야한다.
- 구한 이후, n의 값 이하의 합을 해야하기 때문에 for문을 사용한다.
- 짝수의 경우, 짝수일 때만 제곱수를 더해야하기 때문에, for문에서 짝수의 경우를 추출하고,
- Math.pow(a,b) 함수를 사용하여 제곱수를 구한다. a = 값, b= 제곱수이다. ex) a=2, b=3 이면 2의 3승이 된다.
- 홀수의 경우, 홀수일 때만 값을 더해야하기 때문에 for문에서 홀수의 조건식에서 값을 합해준다.
반응형
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 배열 뒤집기 (for문, Stream 사용) (0) | 2023.08.10 |
---|---|
[프로그래머스] 없는 숫자 더하기 (0) | 2023.08.10 |
[프로그래머스] 나누어 떨어지는 숫자 배열 (0) | 2023.08.09 |
댓글