Ming's develop story

알고리즘 - 두 정수 사이의 합 (21.11.08) 본문

스파르타코딩클럽 - 항해99/항해99 Chapter2 - 알고리즘 기초

알고리즘 - 두 정수 사이의 합 (21.11.08)

Ming 2021. 11. 8. 20:06
  • 두 정수 사이의 합

문제 설명

두 정수 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

 

 

-----------------------------------------------------------------------------------------------------------------------------------

내 풀이

1. if문으로 a가 b보다 작다면 for문을 활용하여 a부터 b까지 더해주도록 한다.

 

2. 반대로 a가 b보다 크다면 b부터 a까지 더해주도록 한다.

 

3. 두 수가 같은경우에도 else에 포함되어 실행되게 되는데 어짜피 한번밖에 실행되지 않아서 따로 설정해 줄 필요가 없다.

 

 

 

 

 

같은 조 은희님의 풀이

- Math.min() 함수는 숫자의 최솟값을 구하는 함수

- Math.max() 함수는 숫자의 최댓값을 구하는 함수

 

 

다른사람의 풀이

"가우스의 재림"

 

양 끝의 합 * 양 끝의 합의 갯수를 표현한 코드

여기서 Math.abs() 함수는 숫자의 절대값을 구하는 함수이다.

(a+b는 양 끝의 합이고 / Math.abs(b-a)+1은 양 끝의 합의 갯수이다.)

이를 "가우스의 재림"이라고 한다.

 

p.s 수학 공부도 다시 해야하나...ㅋㅋ

Comments