1. 문제
2. 해결방안
당연한 말이지만 .. 누적합을 사용했다
prefix_sum 이라는 배열을 통해 원소를 하나씩 탐색하며 그 원소를 이전까지 더해준 값에 더해서 넣어줬다 ~ !
그리고 i~j 까지의 합은 prefix_sum[j] - prefix_sum[i-1] !!
3. 코드
import sys
input = sys.stdin.readline
n,m = map(int,input().split())
nums = list(map(int,input().split()))
prefix_sum=[0]
sum = 0
for n in nums:
sum += n
prefix_sum.append(sum)
for _ in range(m):
i,j = map(int,input().split())
print(prefix_sum[j] - prefix_sum[i-1])
'Koala - 10기 > 코딩테스트 준비 스터디' 카테고리의 다른 글
[백준/Python] 9205번 맥주마시면서 걸어가기 (0) | 2023.05.03 |
---|---|
[백준 / python] 21318. 피아노 체조 (0) | 2023.04.03 |
[백준/Python] 17951 흩날리는 시험지 속에서 내 평점이 느껴진거야 (0) | 2023.04.02 |
[백준/Python] 1184 귀농 (0) | 2023.04.02 |
[백준/Python] #14627 파닭파닭 (0) | 2023.04.01 |