알고리즘/프로그래머스
[프로그래머스 / Python] 두 정수 사이의 합 | 초코더
cloud_nice
2020. 1. 3. 18:05
문제 설명
두 정수 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 |
접근법
우선 a와 b중에서 어떤수가 더 큰지 몰라서 a와 b중 큰수와 작은수 먼저 구분해주었습니다.
그리고 n_sum 변수에 a와 b사이의 정수를 모두 합해주었습니다.
먼저 n_sum에 가장 작은 정수를 넣어두고, 반복문을 돌렸는데
반복문의 범위는 큰수에서 작은수 뺀 차이만큼 반복횟수를 주었고
n_sum에는 작은 수(small)보다 i만큼 큰수를 계속 더해줍니다.(가장큰수(big)까지만)
나의 코드
def solution(a, b):
big = max(a,b)
small = min(a,b)
n_sum = small
for i in range(1,big-small+1):
n_sum += small+i
return n_sum
다른 코드
def adder(a, b):
if a > b: a, b = b, a
return sum(range(a,b+1))