码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 前缀和(区间和,子矩阵的和)


    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. }

  • 相关阅读:
    70. 爬楼梯 (进阶),322. 零钱兑换,279.完全平方数
    Netty简介及简单客户端/服务端示例代码
    Canvas绘制矢量图问题,怎么去掉不是完整的矩形
    大数据讲课笔记1.4 进程管理
    对射式红外传感器模块、测速传感器模块、计数器模块、电机测试模块、槽型光耦模块
    JS学习总结
    关于pycharm打开时一直加载中的解决办法
    UML精简概述
    IntentFilter笔记
    场景中的解剖学方向标记_vtkAnnotatedCubeActor
  • 原文地址:https://blog.csdn.net/qq_51825761/article/details/126126278
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号