当前位置: 首页 > news >正文

asp 手机网站自动app优化

asp 手机网站,自动app优化,青岛建设官方网站,中国营销型网站🍎 博客主页:🌙披星戴月的贾维斯 🍎 欢迎关注:👍点赞🍃收藏🔥留言 🍇系列专栏:🌙 蓝桥杯 🌙我与杀戮之中绽放,亦如黎明的花…

🍎 博客主页:🌙@披星戴月的贾维斯
🍎 欢迎关注:👍点赞🍃收藏🔥留言
🍇系列专栏:🌙 蓝桥杯
🌙我与杀戮之中绽放,亦如黎明的花朵🌙
🍉一起加油,去追寻、去成为更好的自己!

蓝桥杯倒计时 45天

文章目录

  • 🍎、前缀和
  • 🍎、例题分析
        • 🍇、[(AcWing)前缀和](https://www.acwing.com/problem/content/797/)
        • 🍇、[(AcWing)子矩阵的和](https://www.acwing.com/problem/content/798/) 二维前缀和
        • 🍇、[(AcWing)截断数组](https://www.acwing.com/problem/content/description/3959/)
  • 🍎、总结

提示:以下是本篇文章正文内容,下面案例可供参考


🍎、前缀和

🍉、前缀和的简单概念

前缀和算法分为一维和二维,一维前缀和可以很快速的求序列中某一段的和。而二维前缀和可以快速求一个矩阵中某个子矩阵的和。

一维前缀和的图解:
在这里插入图片描述

前缀和数组的计算方法:前缀和数组s[i]是由原数组a[i]递推而来的
即:s[i] = s[i - 1] + a[i]

🍎、例题分析

🍇、(AcWing)前缀和

在这里插入图片描述
分析题意:每次询问查询的是原数组l - r区间内的和, 因此我们可以设置一个原数组a和一个前缀和数组

代码示例:

#include<cstdio>
#include<algorithm>
#include<iostream>
#include<cstring>
using namespace std;
const int N = 100010;
int a[N];//原数组
int s[N];//前缀合数组
int n, m;int main ()
{cin >> n >> m;for(int i = 1; i <= n; i++) {scanf("%d", &a[i]);s[i] = s[i - 1] + a[i];}while(m --){int l , r;cin >> l >> r;printf("%d\n", s[r] - s[l - 1]);}return 0;
}

解法2:因为本题不需要用到原数组a,则可以直接创建一个前缀和数组s,并且原数组a上 L - R 区间内的值就是前缀和数组 s[R] - s[L - 1];
代码示例:

#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
int m, n;
int s[100010];
int main ()
{cin >> n >> m;for(int i = 1; i <= n; i++){scanf("%d", &s[i]);s[i] += s[i - 1];}while(m --){int ans = 0;int l, r;cin >> l >> r;ans = s[r] - s[l - 1];cout << ans << endl;}return 0;
}

🍇、(AcWing)子矩阵的和 二维前缀和

图解二维前缀和的公式
在这里插入图片描述
在这里插入图片描述
代码示例:

#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 1010;
int a[N][N], s[N][N];
int n, m, q;
int main ()
{cin >> n >> m >> q;for(int i =  1; i <= n; i++)for(int j = 1; j <= m; j++){scanf("%d", &a[i][j]);s[i][j] = s[i - 1][j] + s[i][j - 1] - s[i - 1][j - 1] + a[i][j];//计算二维前缀和}while(q --){int x1, x2, y1, y2;//计算每一次结果cin >> x1 >> y1 >> x2 >> y2;int ans = s[x2][y2] - s[x1 -1][y2] - s[x2][y1 - 1] + s[x1 - 1][y1 -1];cout << ans << endl;}return 0;
}

🍇、(AcWing)截断数组

算法:前缀和 + 枚举
在这里插入图片描述
**分析题意:枚举第二刀i处。
在这里插入图片描述
代码示例:

#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long LL;
const int N = 100010;
int n;
int s[N];
int main ()
{cin >> n;for(int i =1; i <= n; i++){int x;scanf("%d", &x);s[i] = s[i - 1]  + x; //处理前缀和数组s[i]}if(s[n] % 3) //提前判断结束条件{cout << "0" << endl;return 0;}LL res = 0;//因为答案可能爆intfor(int i = 3, cnt = 0; i <= n; i++){if(s[i - 2] == s[n] / 3) cnt++;if(s[n] - s[i - 1] == s[n] / 3) res += cnt; //s[n] - s[i - 1]是计算i - n区间的总和}printf("%lld\n", res);return 0;
}

🍎、总结

    本文简要介绍了前缀和的简要概念和几道前缀和的经典例题,希望大家读后能有所收获!

http://www.yayakq.cn/news/397494/

相关文章:

  • 毕业设计网站可以做什么中高风险地区最新名单
  • 广东互联网公司排名网站seo优化主要有哪些手段
  • 营销网站找什么公司做网站开发费应该入什么科目
  • 网站开发可以自学吗成都移动seo
  • 网站建设风险管理施工企业怎样报考a证
  • 宁夏免费建个人网站昆明网站关键字优化
  • 嵊州市建设局网站婚纱摄影哪家好
  • 云虚拟主机怎么做网站wordpress设置网站关键字
  • 专业手机网站开发什么是全网营销推广
  • 广州建设网站是什么样的做外贸推广要做哪些平台
  • 沭阳网站建设wordpress 不能改邮箱
  • 建设银行广东分行网站烟台做网站企业
  • 兰州最大网络公司seo关键词怎么填
  • 网站301检测找不到WordPress
  • 八年级信技做网站中国商标注册网
  • 网站批量收录dede后台做两个网站
  • wordpress建站准备企业查询网
  • 呼和浩特可以做网站的公司网址站
  • 美橙互联网站打不开百度免费域名
  • 做兼职设计去哪个网站萌宝宝投票网站怎么做
  • 下陆区建设局网站医院网站案例
  • 专题网站建设意义何在品牌营销平台
  • 创意个人网站设计织梦网站联系我们的地图怎么做
  • 云南省建设网站wpf做网站
  • 一个网站同时做百度和360推广吗郴州有什么好玩的地方
  • 信息发布类网站模板c PHP做网站对比
  • 重庆给商家企业做网站义乌seo优化公司
  • 建成区违法建设治理网站制作 网站 盈利
  • 电商网站要素宁波网站建设方案推广
  • 网站建设代码排版出错百度SEO网站