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

做网站的好处在哪里阜康管委主任网推app

做网站的好处在哪里阜康管委主任,网推app,茶庄网站模板,手机优化大师官方版题目介绍: 题目链接:【模板】二维前缀和_牛客题霸_牛客网 先举两个简单的例子,来帮大家理解题目,注意理解二维前缀和要先要一维前缀和的基础,不了解的可以看我上一篇博客。 若x11,y11, x23, y2 3,这是要…

题目介绍:

题目链接:【模板】二维前缀和_牛客题霸_牛客网

 

先举两个简单的例子,来帮大家理解题目,注意理解二维前缀和要先要一维前缀和的基础,不了解的可以看我上一篇博客。

若x1=1,y1=1, x2=3, y2 = 3,这是要查询下面这片区域的和:

若x1=3,y1=3, x2=6, y2 = 5,这是要查询下面这片区域的和: 

算法原理:

暴力解法很简单,直接死算,必定超时,所以还是要构建我们的前缀和数组(dp),dp数组的构建方法绝不能是每个数据都死死的去加一遍,不然和暴力解法没什么区别,也会超时。

构建二维前缀和数组(重点):

如何更高效地构造二维前缀和数组呢,之前构建一维前缀和数组时,我们可以很快用肉眼看出规律,但二维前缀和数组的构建方法需要我们画图,寻找新方法:

我们将原数组划分为4个部分,此时我们要求dp[i][j]的大小,其实就是整个图形的面积也就是A+B+C+D,A很好表示,A=dp[i-1][j-1],D就一个元素也很好表示,D=arr[i][j] ,可是B和C却不好表示,但是A+B和A+C我们却很好表示,A+B=dp[i-1][j],A+C=dp[i][j-1],如图:

所以我们就得出了我们的重要结论:

dp[i][j]=dp[i-1][j]+dp[i][j-1]-dp[i-1][j-1]+arr[i][j] 

通过这个表达式我们就能构建出二维前缀和数组了。

使用二维前缀和数组:

我们已经构建出了二维前缀和数组,那么如何使用它呢,如图,我们输入x1,y1,x2,y2后:

还是一样先划分为A,B,C,D  4个区域:

此时D为我们所求,还是根据刚才的思路,来换算:

D=A+B+C+D-(A+B+C)

A+B+C+D=dp[x2][y2]

B和C单独在一块不好求,就转化成A+B和A+C,如:

D=A+B+C+D-(A+B+C)=A+B+C+D-(A+B)-(A+C)+A=dp[x2][y2]-dp[x1-1][y2]-dp[x2][y1-1]+dp[x1-1][y1-1]

所以的出重要结论:

D=dp[x2][y2]-dp[x1-1][y2]-dp[x2][y1-1]+dp[x1-1][y1-1]

最后我们只需将x1,y1,x2,y2代入上式中就可以求得答案了。

代码实现:

C++: 

#include <iostream>
#include<vector>
using namespace std;int main() {//读入数据int n =0,m=0,q=0;cin >> n >> m >> q;vector<vector<int>> arr(n+1, vector<int>(m+1));int i=1;for(i=1;i<=n;i++){int j=1;for(j=1;j<=m;j++){cin >> arr[i][j];}}//处理dp数组vector<vector<long long>> dp(n+1, vector<long long>(m+1));for(i=1;i<=n;i++){int j=1;for(j=1;j<=m;j++){dp[i][j]=dp[i-1][j]+dp[i][j-1]-dp[i-1][j-1]+arr[i][j];}}//开始使用dp数组进行q次查询while(q--){int x1=0,y1=0,x2=0,y2=0;cin >> x1 >> y1 >> x2 >> y2;cout << dp[x2][y2]-dp[x1-1][y2]-dp[x2][y1-1]+dp[x1-1][y1-1] << endl;}return 0;
}

http://www.dinnco.com/news/27617.html

相关文章:

  • 网上有兼职做数据网站整合营销包括哪三方面
  • wordpress多站点设置seo外包 靠谱
  • 网站搭建书籍推荐百度搜索平台
  • 商业网站建设视频教程旅游景区网络营销案例
  • 专业从事成都网站建设抖音推广佣金平台
  • 景区旅游网站平台建设方案你就知道首页
  • 深圳专业集团网站建设百度风云榜小说排行榜历届榜单
  • wordpress让浏览显示K单位seo有哪些网站
  • 网站 html 作用百度竞价登录入口
  • 网站公司怎么做推广网站友链
  • 保险网站模板网络营销推广是做什么的
  • 瑞达恒建筑网站免费建网站的平台
  • 建设网站制作公司如何选择关键词seo公司真实推荐
  • 有谁可以做网站寄生虫客户管理软件哪个好用
  • 设计优秀的网站推荐推销产品怎么推广
  • 黄山网站建设有哪些营销策划方案案例范文
  • 建搜索引擎网站预防电信网络诈骗
  • 扬州邗江建设局网站网站制作教程
  • 有没有给人做简历的网站网站提交链接入口
  • asp.net 项目成本预算系统的 网站开发免费模式营销案例
  • 做网站开发考什么研百度浏览器官网下载
  • 网站上传的图片怎么做的清晰度石家庄关键词优化报价
  • 佛山做外贸网站的公司如何在百度提交自己的网站
  • 无锡网站制作推广类软文
  • app网站开发价格国内新闻最新消息10条
  • 合肥一浪网络科技有限公司二十条优化疫情措施
  • 域名怎么创建网站吗关键词生成器
  • 软文推广经典案例优化疫情防控措施
  • 做网站报价明细表四川seo推广
  • dw网站制作效果怎么做北京seo报价