Just Do IT!
[프로그래머스 Level 1] 12912. 두 정수 사이의 합 (JavaScript) 본문
728x90
반응형
문제 설명
두 정수 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 |
function solution(a, b) {
// 최솟값=a 최댓값=b
// a 와 b 사이를 for문으로 돌면서 answer에 더하기
let answer = 0;
let num_min = Math.min(a, b);
let num_max = Math.max(a, b);
for (let i = num_min; i <= num_max; i++) {
answer += i;
}
return answer;
}
다른 사람 풀이
function solution(a, b){
return (a+b)*(Math.abs(b-a)+1)/2;
}
생각해보니까, a와 b 사이의 숫자들의 합은 공식을 통해서 구하면 쉬운 거였는데...!! 그걸 생각 못했다.
a < b 일 때, (a+b)*(b - a - 1)/2 = a부터 b의 합
이 걸 생각했었으면 다른 분이 풀었던 풀이처럼 간결하게 나올 수 있었다.
Math.abs() 는 주어진 숫자의 절댓값을 반환하므로 필요하다.
늘 다른 사람들 풀이를 보며 많이 배우는 것 같다.
728x90
'코딩테스트 준비 > Level 1' 카테고리의 다른 글
[프로그래머스 Level 1] 12910. 나누어 떨어지는 숫자 배열 (JavaScript) (0) | 2023.02.02 |
---|---|
[프로그래머스 level 1] 86051. 없는 숫자 더하기 (JavaScript) (0) | 2023.02.01 |
[프로그래머스 Level 1] 12947. 하샤드 수 (JavaScript) (0) | 2023.01.29 |
[프로그래머스 Level 1] 87389. 나머지가 1이 되는 수 찾기 (JavaScript) (0) | 2023.01.28 |
[프로그래머스 Level 1] 12925. 문자열을 정수로 바꾸기 (JavaScript) (0) | 2023.01.24 |