티스토리 뷰
728x90
https://www.acmicpc.net/problem/1292
- 문제 :
동호는 내년에 초등학교를 입학한다. 그래서 동호 어머니는 수학 선행 학습을 위해 쉽게 푸는 문제를 동호에게 주었다
.
이 문제는 다음과 같다. 1을 한 번, 2를 두 번, 3을 세 번, 이런 식으로 1 2 2 3 3 3 4 4 4 4 5 .. 이러한 수열을 만들고 어느 일정한 구간을 주면 그 구간의 합을 구하는 것이다.
하지만 동호는 현재 더 어려운 문제를 푸느라 바쁘기에 우리가 동호를 도와주자.
- 풀이 :
구현 문제였습니다
s라는 list를 선언하고 1, 2, 2, 3, 3, 3, 4, 4...... 이렇게 담아줍니다.
a부터 b 구간까지를 slice하여 sum 함수를 통해 합을 출력합니다.
주의할 점 ) s를 리스트가 아닌 문자열로 해서 더해줄 경우 a부터 b번째 자릿수가 아닌 숫자의 합을 구하는 문제이므로
10을 더해야 할 때 1과 0으로 나누어서 정답에 더해주는 문제가 발생할 수 있습니다.
- 소스코드 :
import sys
input= sys.stdin.readline
s = []
a,b = map(int,input().split())
for i in range(1000):
for _ in range(i):
s.append(i)
print(sum(list(s)[a-1:b]))
320x100
'Algorithm > Implementation' 카테고리의 다른 글
(Python/파이썬) - 백준(BOJ) 2344번 : 거울 (0) | 2022.06.13 |
---|---|
(Python/파이썬) - 백준(BOJ) 11559번 : Puyo Puyo (0) | 2022.06.08 |
(Python/파이썬) - 백준(BOJ) 3709번 : 레이저빔은 어디로 (0) | 2022.05.23 |
(Python/파이썬) - 백준(BOJ) 1068번 : 트리 (0) | 2022.05.20 |
(Python/파이썬) - 백준(BOJ) 8972번 : 미친 아두이노 (0) | 2022.05.19 |
댓글
© 2022 WonSeok, All rights reserved