https://programmers.co.kr/learn/courses/30/lessons/12912
[문제]
두 정수 a, b가 주어졌을 때 a와 b 사이에 속한 모든 정수의 합을 리턴하는 함수, solution을 완성하세요.
예를 들어 a = 3, b = 5인 경우, 3 + 4 + 5 = 12이므로 12를 리턴합니다.
[제한 조건]
- a와 b가 같은 경우는 둘 중 아무 수나 리턴하세요.
- a와 b는 -10,000,000 이상 10,000,000 이하인 정수입니다.
- a와 b의 대소관계는 정해져있지 않습니다.
[코드]
class Solution {
public long solution(int a, int b) {
long answer=0;
// a와 b중 작은 수를 시작 숫자, 큰 숫자를 마지막 숫자로 저장한다.
int max=Math.max(a, b);
int min=Math.min(a, b);
// a와 b중 작은 숫자부터 시작해 큰 숫자까지의 누적 합을 구한다.
for(int i=min;i<=max;i++)
answer+=i;
return answer;
}
}
[고찰]
for문을 사용하여 누적합을 구하기 위해서는 주어진 a와 b중 더 작은 숫자부터 시작해야하기 때문에 a와 b중 어떤 수가 더 작은지 판별해내는 과정이 필요하다. 이 부분만 주의하면 쉽게 해결할 수 있는 문제였다.
'프로그래머스' 카테고리의 다른 글
[프로그래머스_Level1] 같은 숫자는 싫어 (0) | 2021.07.15 |
---|---|
[프로그래머스_Level1] 나누어 떨어지는 숫자 배열 (0) | 2021.07.15 |
[프로그래머스_Level1] 문자열 내 마음대로 정렬하기 (0) | 2021.07.15 |
[프로그래머스_Level1] 문자열 내 p와 y의 개수 (0) | 2021.07.15 |
[프로그래머스_Level1] 문자열 내림차순으로 배치하기 (0) | 2021.07.15 |