[level 1] 두 정수 사이의 합
문제 설명
두 정수 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) {
let answer = 0;
if ( a <= b ) {
for (let i = a; i <= b; i++)
answer += i
} else {
for (let i = b; i <= a; i++) {
answer += i
}
}
return answer;
}
a가 b보다 작거나 같을 때 for문으로 b까지 1개씩 더해주는 걸로 했다. if문도 같이 사용해서 조건을 설정해줬다.
다른 사람 풀이
function adder(a, b){
var result = 0
//함수를 완성하세요
return (a+b) * (Math.abs(a-b)+1) / 2;
}
// 아래는 테스트로 출력해 보기 위한 코드입니다.
console.log( adder(3, 5) )
댓글 중에 핫한 사람의 풀이를 가지고 왔는데, 오... 진짜 이분은 너무나도 잘 푼거 같다. Math.abs는 아래 링크를 올렸다.
이는 절대값을 반환해주는건데, 절대적인 양수로 계산을 하신거 같다.
https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Global_Objects/Math/abs
출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges
'알고리즘 > lv 1' 카테고리의 다른 글
JS 알고리즘 Lv.1 음양 더하기 (0) | 2023.06.16 |
---|---|
JS 알고리즘 Lv.1 없는 숫자 더하기 (0) | 2023.06.16 |
JS 알고리즘 Lv.1 가운데 글자 가져오기 (0) | 2023.06.16 |
JS 알고리즘 Lv.1 짝수와 홀수 (0) | 2023.06.16 |
JS 알고리즘 Lv.1 직사각형 별찍기 (1) | 2023.06.16 |