https://school.programmers.co.kr/learn/courses/30/lessons/12912?language=python3
def solution(a, b):
if a > b:
return sum(int(i) for i in range(b,a+1))
elif a < b:
return sum(int(i) for i in range(a,b+1))
else:
return a
경우의 수 나눠서 생각했다.
다른사람 코드
def adder(a, b):
if a > b: a, b = b, a
return sum(range(a,b+1))
a,b 치환해서 쓰는데 신기했다.
def adder(a, b):
return (abs(a-b)+1)*(a+b)//2
역대급...
1부터 n 까지의 합 공식이 n(n+1)/2니까
n부터 m까지의 합은 (수의 개수) * (끝수 + 첫번째 수) / 2
수의 개수 : abs(a-b)+1
끝수 + 첫번째 수 : a+b
[코딩테스트 입문] 서울에서 김서방 찾기(Python3) (0) | 2023.01.03 |
---|---|
[코딩테스트 입문] 콜라츠 추측(Python3) (0) | 2023.01.03 |
[코딩테스트 입문] 나머지가 1이 되는 수 찾기(Python3) (0) | 2023.01.03 |
[코딩테스트 입문] 정수 내림차순으로 배치하기(Python3) (0) | 2023.01.03 |
[코딩테스트 입문] 하샤드 수(Python3) (0) | 2023.01.02 |