题解 | #【模板】静态区间和(前缀和)#

【模板】静态区间和(前缀和)

https://www.nowcoder.com/practice/ac79a1a4a66646cc87525d6faa86e021

#include <stdio.h>
#include <stdlib.h>
int main() {
    int n, q;
    if (scanf("%d %d", &n, &q) != EOF) {
        int* arr = (int*)malloc(sizeof(int) * n);
        for(int i = 0; i < n; i++) {
            scanf("%d", &arr[i]);
        }
        int l, r;
        long long* sum = (long long*)malloc(sizeof(long long) * (n + 1));
        sum[-1] = 0;
        for(int i = 0; i < n; i++) {
            sum[i] = arr[i] + sum[i - 1];
        }
        for(int i = 0; i < q; i++) {
            scanf("%d %d", &l, &r);
            
            
            printf("%lld\n", sum[r - 1] - sum[l - 2]);
        }
        free(arr);
    } else {
        printf("no input");
    }
    return 0;
}

全部评论

相关推荐

06-02 15:53
阳光学院 Java
点赞 评论 收藏
分享
求offer的大角牛:不吃香菜
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务