누적합(prefix sum)을 dp로 나타내서 구하는 문제
dp[i]는 0부터 i번째 인덱스까지의 합
#include<bits/stdc++.h>
using namespace std;
int n, m;
int arr[100001];
int dp[100001];
int main() {
ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);
cin >> n >> m;
for (int i = 0; i < n; i++) {
cin >> arr[i];
if (i == 0) dp[i] = arr[i];
else {
dp[i] = dp[i - 1] + arr[i];
}
}
while (m--) {
int a, b;
cin >> a >> b;
if (a == 1) {
cout << dp[b-1] << '\n';
}else
cout << dp[b-1] - dp[a - 2] << '\n';
}
}