문제 설명
두 정수 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의 대소관계는 정해져있지 않습니다.
입출력 예
a | b | return |
3 | 5 | 12 |
3 | 3 | 3 |
5 | 3 | 12 |
소스코드
for 를 이용한 풀이 ( 실행 시간 : 10ms 대 까지 나옴 )
class Solution {
public long solution(int a, int b) {
long answer = 0;
for(int i= Math.min(a,b); i<= Math.max(a,b); i++)
answer += i;
return answer;
}
}
등차 수열 공식을 이용한 풀이 ( 실행 시간 : 1ms 미만 )
class Solution {
public long solution(int a, int b) {
long answer = 0;
return sumAtoB(Math.min(a,b),Math.max(a,b));
}
public long sumAtoB(long a, long b){
return (b - a + 1) * (a + b) /2 ;
}
}
'Algorithm > Programmers' 카테고리의 다른 글
문자열 내 p와 y의 개수 (0) | 2020.01.07 |
---|---|
문자열 내 마음대로 정렬하기 (0) | 2020.01.07 |
나누어 떨어지는 숫자 배열 (0) | 2020.01.02 |
같은 숫자는 싫어 (0) | 2019.12.27 |
가운데 글자 가져오기 (0) | 2019.12.26 |