-
[프로그래머스 / Python] 두 정수 사이의 합 | 초코더알고리즘/프로그래머스 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))
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[프로그래머스 / Python] 같은 숫자는 싫어 | 초코더 (0) 2020.01.03 [프로그래머스 / Python] 문자열 내 p와 y의 개수 | 초코더 (0) 2020.01.03 [프로그래머스 /Python] 2016년 | 초코더 (0) 2020.01.03 [프로그래머스 / Python] 수박수박수박수박수박수? | 초코더 (0) 2020.01.02 [프로그래머스 / Python] 서울에서 김서방 찾기 | 초코더 (0) 2020.01.02