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

中国建设手机银行网站推广型网站建设模板

中国建设手机银行网站,推广型网站建设模板,高级网络规划设计师,外贸网上推广前缀和 文章目录 前缀和一维应用 二维差分一维 二维扩展1、前缀和与哈希表 一维 一个数组prefix中,第i个元素表示nums[0]至nums[i-1]的总和,那么我们就称这个prefix数组是nums数组的前缀和。 prefix [ i ] ∑ j 0 i nums [ j ] \text{prefix}[i] \s…

前缀和

文章目录

  • 前缀和
    • 一维
      • 应用
    • 二维
    • 差分
      • 一维
    • 二维
    • 扩展
      • 1、前缀和与哈希表

一维

一个数组prefix中,第i个元素表示nums[0]nums[i-1]的总和,那么我们就称这个prefix数组是nums数组的前缀和。
prefix [ i ] = ∑ j = 0 i nums [ j ] \text{prefix}[i] = \sum_{j=0}^{i} \text{nums}[j] prefix[i]=j=0inums[j]

应用

1、快速计算下标为[i , j]区间的和。

  • prefix[j+1]- prefix[i]即为下标[i , j]之间元素的总和。

二维

matrix-sum.png

class NumMatrix {vector<vector<int>> sum;
public:NumMatrix(vector<vector<int>> &matrix) {int m = matrix.size(), n = matrix[0].size();sum.resize(m + 1, vector<int>(n + 1));for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {sum[i + 1][j + 1] = sum[i + 1][j] + sum[i][j + 1] - sum[i][j] + matrix[i][j];}}}// 返回左上角在 (r1,c1) 右下角在 (r2,c2) 的子矩阵元素和int sumRegion(int r1, int c1, int r2, int c2) {return sum[r2 + 1][c2 + 1] - sum[r2 + 1][c1] - sum[r1][c2 + 1] + sum[r1][c1];}
};作者:灵茶山艾府
链接:https://leetcode.cn/problems/range-sum-query-2d-immutable/solutions/2667331/tu-jie-yi-zhang-tu-miao-dong-er-wei-qian-84qp/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

差分

一维

所谓“差分”,是指原数组中每个元素与前一元素之差所形成的数组
我们知道,对原数组进行诸位累加(前缀计算操作),所得到的数组为前缀和数组。差分数组,则是对其执行前缀计算后,能够得到原数组的那个数组 。

差分数组的主要作用,是帮助快速修改某段区间。

因此,当我们想要对原数组的 [l,r] 进行整体修改时,只需要对差分数组的lr+1 位置执行相应操作即可。

二维

扩展

1、前缀和与哈希表

力扣560.和为k的子数组
借助哈希表中判定重复元素的功能,可以帮忙判断(当前的前缀和-K)是否出现在哈希表中,如果有那么久数量加一,如果没有就将当前前缀和压入哈希表。

class Solution {
public:int subarraySum(vector<int>& nums, int k) {unordered_map<int, int> haxi; // 用于存储前缀和出现次数haxi[0] = 1; // 初始化,表示前缀和为0出现一次vector<int> qian(nums.size() + 1, 0); // 前缀和数组int ans = 0;// 计算前缀和for (int i = 1; i <= nums.size(); i++) {qian[i] = nums[i - 1] + qian[i - 1];}// 查找满足条件的子数组for (int i = 1; i <= nums.size(); i++) {int complement = qian[i] - k;if (haxi.find(complement) != haxi.end()) {ans += haxi[complement]; // 增加满足条件的子数组个数}haxi[qian[i]]++; // 更新当前前缀和的出现次数}return ans;}
};

或者也可以一次遍历即可。在遍历的同时判断(当前的前缀和-K)是否出现在哈希表中。

class Solution {
public:int subarraySum(vector<int>& nums, int k) {int ans = 0, s = 0;unordered_map<int, int> cnt{{0, 1}}; // s[0]=0 单独统计for (int x : nums) {s += x;// 注意不要直接 += cnt[s-k],如果 s-k 不存在,会插入 s-kans += cnt.contains(s - k) ? cnt[s - k] : 0;cnt[s]++;}return ans;}
};作者:灵茶山艾府
链接:https://leetcode.cn/problems/subarray-sum-equals-k/solutions/2781031/qian-zhui-he-ha-xi-biao-cong-liang-ci-bi-4mwr/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
http://www.15wanjia.com/news/180595.html

相关文章:

  • 在360怎么做网站群晖nas安装wordpress安装
  • 上海市住宅建设发展中心网站怎么做线上推广
  • 专门做ppt的网站斧头wordpress获取页面的当前位置
  • 企业设计网站公司哪家好用什么做网站更快捷方便
  • 比较好的微网站开发平台小程序代码大全
  • 怎么做网站一张图PS做网站页面尺寸
  • 网站可以做砍价软件吗做外贸网站卖什么东西好
  • 新手做网站做什么样的seo综合查询什么意思
  • 装修网站建设优缺点仿网站工具
  • 杭州设计企业网站高端公司wordpress怎么把图片存七牛
  • 如何进行公司网站的建设交网站建设域名计入什么科目
  • 单页网站设计欣赏快速做效果图的网站叫什么区别
  • 手机免费资源下载网站模板配置wordpress七牛
  • 网站开发与设计实训总结产品网上推广的方法有哪些
  • 做单页网站要多少钱优质的武进网站建设
  • 微网站定制logo设计公司怎么去跟客户谈
  • 关于网站开发专业的ppt30天网站建设 视频
  • 公司网站首页怎么制作wordpress下载管理器
  • 电话开发网站建设话术wordpress 模板 设置
  • 如何在手机上搭建网站公司邮箱格式
  • 做知识问答的网站网站页面做多宽
  • 大连网站的建设怎么优化WordPress主题
  • 厦门企业做网站电子商务网站费用预算
  • 用phython做网站新手搭建论坛己做网站
  • 承德信息网58上海自动seo
  • cod建站平台推销一个产品的方案
  • 商城网站怎么做seo镇江网站建设报价
  • 镇江房产网站建设大学生做兼职的网站有哪些
  • 西安博威建设工程有限公司招聘网站jsp网站建设项目实战总结
  • 瑞安公司做网站wordpress导航读取