Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 데이콘
- ubuntu
- 편스토랑
- Docker
- 파이썬
- SW Expert Academy
- AI 경진대회
- 더현대서울 맛집
- 캐치카페
- programmers
- 자연어처리
- 코로나19
- 프로그래머스 파이썬
- 우분투
- 백준
- 금융문자분석경진대회
- leetcode
- 편스토랑 우승상품
- hackerrank
- Real or Not? NLP with Disaster Tweets
- Git
- gs25
- 맥북
- Baekjoon
- github
- Kaggle
- 프로그래머스
- PYTHON
- dacon
- ChatGPT
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 11659번 : 구간 합 구하기 4 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 백준의 구간 합 구하기 4 입니다.
👨🏻💻 문제 풀이
엄청 쉬워보여서 빨리 풀고 다른 남은 작업을 진행해보려고 했는데
생각보다 시간초과 문제 때문에 너무 오랜 시간 풀었던 문제 입니다.
def get_div_sum_4(numbers, i, j):
return sum(numbers[i-1:j])
if __name__ == "__main__":
numbers_len, loop_num = map(int, input().split())
numbers = list(map(int, input().split()))
for i in range(loop_num):
i, j = map(int, input().split())
print(get_div_sum_4(numbers, i, j))
처음에는 입력받은 인덱스 번호를 활용하여 리스트 슬라이싱을 활용 했던 것과
for 반복문을 활용하여 입력받은 수 만큼 수행하는 부분을 구현하였더니 시간 초과가 발생했습니다.
이에 itertools의 accumulate를 활용하여 누적합 리스트를 만들어 활용했고
numbers_len, loop_num = map(int, sys.stdin.readline().split())
numbers = list(map(int, sys.stdin.readline().split()))
numbers = list(accumulate(numbers))
numbers.append(0)
for 반복문을 while 반복문을 활용하여 입력 받은 수 만큼 수행하는 부분을 구현하니 해결되었습니다.
break_num = 0
while loop_num > break_num:
i, j = map(int, sys.stdin.readline().split())
print(get_div_sum_4(numbers, i, j))
break_num += 1
👨🏻💻 코드 ( Solution )
from itertools import accumulate
import sys
def get_div_sum_4(numbers, i, j):
return numbers[j-1] - numbers[i-2]
if __name__ == "__main__":
numbers_len, loop_num = map(int, sys.stdin.readline().split())
numbers = list(map(int, sys.stdin.readline().split()))
numbers = list(accumulate(numbers))
numbers.append(0)
break_num = 0
while loop_num > break_num:
i, j = map(int, sys.stdin.readline().split())
print(get_div_sum_4(numbers, i, j))
break_num += 1
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaekJoon] 2752번 : 세수정렬 (Python) (0) | 2021.12.05 |
---|---|
[BaekJoon] 2910번 : 빈도 정렬 (Python) (0) | 2021.12.04 |
[BaekJoon] 10952번 : A+B - 5 (Python) (0) | 2021.12.02 |
[SW Expert Academy] 2029번 : 몫과 나머지 출력하기 (Python) (0) | 2021.12.01 |
[SW Expert Academy] 1976번 : 시각 덧셈 (Python) (0) | 2021.11.30 |
Comments