[입문] 연속된 수의 합
문제 설명
연속된 세 개의 정수를 더해 12가 되는 경우는 3, 4, 5입니다. 두 정수 num과 total이 주어집니다. 연속된 수 num개를 더한 값이 total이 될 때, 정수 배열을 오름차순으로 담아 return하도록 solution함수를 완성해보세요.
제한사항
- 1 ≤
num≤ 100 - 0 ≤
total≤ 1000 num개의 연속된 수를 더하여total이 될 수 없는 테스트 케이스는 없습니다.
입출력 예
| num | total | result |
|---|---|---|
| 3 | 12 | [3, 4, 5] |
| 5 | 15 | [1, 2, 3, 4, 5] |
| 4 | 14 | [2, 3, 4, 5] |
| 5 | 5 | [-1, 0, 1, 2, 3] |
입출력 예 설명
입출력 예 #1
num= 3,total= 12인 경우 [3, 4, 5]를 return합니다.
입출력 예 #2
num= 5,total= 15인 경우 [1, 2, 3, 4, 5]를 return합니다.
입출력 예 #3
- 4개의 연속된 수를 더해 14가 되는 경우는 2, 3, 4, 5입니다.
문제 풀이
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
class Solution {
public int[] solution(int num, int total) {
int[] answer = new int[num];
int tmp = 0;
for (int i = 0; i < num; i++) {
tmp += i;
}
int value = (total - tmp) / num;
for (int i = 0; i < num; i++) {
answer[i] = i + value;
}
return answer;
}
}
댓글남기기