• 前缀和(区间和,子矩阵的和)


    795. 前缀和

    输入一个长度为 n

    的整数序列。

    接下来再输入 m

    个询问,每个询问输入一对 l,r

    对于每个询问,输出原序列中从第 l

    个数到第 r

    个数的和。

    输入格式

    第一行包含两个整数 n

    和 m

    第二行包含 n

    个整数,表示整数数列。

    接下来 m

    行,每行包含两个整数 l 和 r

    ,表示一个询问的区间范围。

    输出格式

    共 m

    行,每行输出一个询问的结果。

    数据范围

    1≤l≤r≤n

    ,
    1≤n,m≤100000,
    −1000≤数列中元素的值≤1000

    输入样例:

    1. 5 3
    2. 2 1 3 6 4
    3. 1 2
    4. 1 3
    5. 2 4

    输出样例:

    1. 3
    2. 6
    3. 10

    s[i]=s[i-1]+a[i]   //s[i]表示数组a  的前i项和:

    1. #include
    2. #include
    3. #include
    4. using namespace std;
    5. const int maxn=1e5+10;
    6. int a[maxn],s[maxn];
    7. int main()
    8. {
    9. int n,m;
    10. cin >> n >> m;
    11. for (int i = 1; i <= n; i ++ )
    12. {
    13. cin >> s[i];
    14. s[i]+=s[i-1]; //前缀和的计算
    15. }
    16. while (m -- )
    17. {
    18. int l,r;
    19. cin >> l >> r;
    20. cout << s[r]-s[l-1] << endl; //区间和的计算
    21. }
    22. return 0;
    23. }

    796. 子矩阵的和

    输入一个 n

    行 m 列的整数矩阵,再输入 q 个询问,每个询问包含四个整数 x1,y1,x2,y2

    ,表示一个子矩阵的左上角坐标和右下角坐标。

    对于每个询问输出子矩阵中所有数的和。

    输入格式

    第一行包含三个整数 n,m,q

    接下来 n

    行,每行包含 m

    个整数,表示整数矩阵。

    接下来 q

    行,每行包含四个整数 x1,y1,x2,y2

    ,表示一组询问。

    输出格式

    共 q

    行,每行输出一个询问的结果。

    数据范围

    1≤n,m≤1000

    ,
    1≤q≤200000,
    1≤x1≤x2≤n,
    1≤y1≤y2≤m,
    −1000≤矩阵内元素的值≤1000

    输入样例:

    1. 3 4 3
    2. 1 7 2 4
    3. 3 6 2 8
    4. 2 1 2 3
    5. 1 1 2 2
    6. 2 1 3 4
    7. 1 3 3 4

    输出样例:

    1. 17
    2. 27
    3. 21

    1. #include
    2. #include
    3. #include
    4. using namespace std;
    5. const int N = 1010;
    6. int s[N][N]={0};
    7. void Insert(int x,int y,int val) //在a[x][y]处加一个值
    8. {
    9. s[x][y]=s[x-1][y]+s[x][y-1]-s[x-1][y-1]+val;
    10. }
    11. int Search(int x1,int y1,int x2,int y2) //返回(x1,y1) 到 (x2,y2)区间的和
    12. {
    13. return s[x2][y2]-s[x2][y1-1]-s[x1-1][y2]+s[x1-1][y1-1];
    14. }
    15. int main()
    16. {
    17. int n,m,q;
    18. scanf("%d%d%d", &n, &m,&q);
    19. for(int i=1;i<=n;++i)
    20. for(int j=1;j<=m;++j)
    21. {
    22. int val;
    23. scanf("%d",&val);
    24. Insert(i,j,val);
    25. }
    26. while(q--)
    27. {
    28. int x1,y1,x2,y2;
    29. scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
    30. printf("%d\n",Search(x1,y1,x2,y2));
    31. }
    32. return 0;
    33. }

  • 相关阅读:
    No module named ‘PyQt5.QtWebEngineWidgets‘kn-----已解决
    python数据分析——数据分类汇总与统计
    vue2.0 双向绑定原理分析及简单实现
    Haskell:嵌套函子
    Day 00 python基础认识与软件安装
    引流、变现、留存解决方案—“消费”+“分享”的聚合生态-分享购
    1、什么是NFT
    SDL2 播放音频(MP4)
    DM8实时主备与读写分离的区别
    Java国密加密SM3代码
  • 原文地址:https://blog.csdn.net/qq_51825761/article/details/126126278