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

网站到底是域名需要备案还是空间drupal wordpress 性能

网站到底是域名需要备案还是空间,drupal wordpress 性能,可以引流推广的app,福建省建设资格注册管理中心网站前言 1.前缀和哈希表(排列组合思想) 2.同余定理 3.Cpp和Java修正【负数%正数】 (num%k k)% k 题目解析 和可被K整除的子数组: 给定一个整数数组 nums 和一个整数 k ,返回其中元素之和可被 k 整除的非…

前言

1.前缀和+哈希表(+排列组合思想)

2.同余定理

3.Cpp和Java修正【负数%正数】

(num%k + k)% k

题目解析

和可被K整除的子数组:

给定一个整数数组 nums 和一个整数 k ,返回其中元素之和可被 k 整除的非空 子数组 的数目。

子数组 是数组中 连续 的部分。

本题在leetcode560“和为K的子数组”这道题上进行了扩展,

但同样是--统计一段和满足某条件的连续区间(子数组)的数目。

算法原理

暴力解法

用两层循环遍历所有子数组的情况,求和看是否满足条件。

虽然容易想,但并非毫无意义:在想暴力解法的过程中,我们会发现题目所给数组包含负数和0,不具有单调性,因此不能用双指针“滑动窗口”进行优化。那怎么办?

前缀和+哈希表

在学完前缀和以后,每当看到题目要求连续区间的和时,都应该想到前缀和,毕竟在有了前缀和之后,求某段区间的和都只需要O(1)就能完成。

那么如何用前缀和优化又是个问题。

为了使用前缀和,首先要一改暴力解法的思想:以i位置为起点遍历所有子数组。、这样我们只能求出后缀和,与前缀和完全不搭边。

那么反过来想,遍历以i位置为结尾的子数组,似乎就好起来了,既能考虑所有子数组的情况,又能使用前缀和。当有了i位置的前缀和之和,其实就不需要再一个一个遍历子数组的情况了。

因为sum[i,j] = prefix_sum[j] - prefix[i]。有了两个前缀和,就能够算出这两段前缀和之间的值。(图中抽象表示,未处理细节)

在知道要使用前缀和的情况下,再观察一下题目要求:和可被K整除的子数组。

子数组不就是sum[i,j] = prefix_sum[j] - prefix[i]这个嘛。且和能够用前缀和之差表示,再结合同余定理,就会发现找到 j 位置时,只要前面 j 前有 i 位置,满足二者的前缀和(mod)k相等,就能推出sum[i,j]这段子数组之和能被K整除,只需要把下面的逻辑逆着推上来即可。

这样,用哈希表记录下某位置之前的前缀和,结合哈希表快速查找的特性,

就可以在到 i 位置时, 查找之前满足条件的前缀和出现的次数,就是满足条件的子数组的个数。

(哈希中可以只存前缀和模K的余数及其出现的次数)

注意的细节就是,哈希表需要初始化map[0] = 1。这是因为可能某位置的前缀和就刚好满足条件,那么子数组就是该段前缀和减去一个0,需要在哈希表中找到一个为0的前缀和。换种理解就是,index在-1位置时,前缀和为0。

还有,数组中存在负数,对于取模操作,Cpp 和Java 的 [ 负数%正数 == 负数 ]

可是对K取模运算余数的范围是[0,K-1],是正数,就需要特殊处理。

对负数:(num % k)+ k ;但正数不需要啊

有一个正负取模统一表达式:(num%k + k)% k; 就行了。

代码实现

不需要真的创建一个数组存前缀和,都放到哈希表中即可。

int subarraysDivByK(vector<int>& nums, int k) {int n = nums.size(), sum = 0, ct = 0;unordered_map<int, int> m;m[0]++;for (int e : nums) {sum += e;ct += m[(sum % k + k) % k];m[(sum % k + k) % k]++;}return ct;}

还有一种排列组合的思路,把前缀和模K都求出后放入哈希,相同的余数两两进行排列组合,也是满足条件的子数组。

int subarraysDivByK(vector<int>& nums, int k) {int n = nums.size(), sum = 0, ct = 0;unordered_map<int, int> m;m[0]++;for(int e : nums){sum+=e;m[(sum%k+k)%k]++;}for(auto [k,v] : m){ct += v*(v-1)/2;}return ct;}

 


文章转载自:

http://4UCxAtfw.hLfnh.cn
http://1grIQcph.hLfnh.cn
http://EddeYkpM.hLfnh.cn
http://fdjfa7Ic.hLfnh.cn
http://n5WPsxvQ.hLfnh.cn
http://LvIDLamH.hLfnh.cn
http://FcZHb9qr.hLfnh.cn
http://9FYwsLwM.hLfnh.cn
http://021kOXfL.hLfnh.cn
http://lz4cq184.hLfnh.cn
http://k2FeTzxl.hLfnh.cn
http://ftFG7QF9.hLfnh.cn
http://pdS4lP1w.hLfnh.cn
http://wLpW4o3T.hLfnh.cn
http://HllWleBQ.hLfnh.cn
http://3IOYotLB.hLfnh.cn
http://QmVhGrKS.hLfnh.cn
http://PYcxgnkY.hLfnh.cn
http://bxYvQSFL.hLfnh.cn
http://D7PPCEun.hLfnh.cn
http://wGJw0J37.hLfnh.cn
http://IbjYQWVX.hLfnh.cn
http://AkcIape3.hLfnh.cn
http://xRXd8hWa.hLfnh.cn
http://AYjz2BYd.hLfnh.cn
http://hBg3Lwcd.hLfnh.cn
http://gNu0jYzw.hLfnh.cn
http://nziZE1hN.hLfnh.cn
http://M1cMySUI.hLfnh.cn
http://BKBHzDZo.hLfnh.cn
http://www.dtcms.com/wzjs/720212.html

相关文章:

  • 网站的投票 计数模块怎么做上海工商网上办事大厅电话
  • 网站建设不好做app界面设计用什么软件
  • 深圳本地招聘网站有哪些做计划网站
  • 太原论坛网站开发公司保定市网站制作公司
  • 专门做设计的网站对网站主要功能界面进行赏析
  • wordpress yusi1.0seo网站托管
  • 专门做2次元图片的网站wordpress定義小工具
  • 网站推广互联网推广怎样进行seo优化
  • 济南响应式网站开发抖音运营推广
  • 做导航网站用什么cms网页设计及网站建设的相关概念
  • 惠州建站模板wp做网站需要多久
  • 山东金泰建设有限公司网站一流的苏州网站建设
  • 网站开发语言哪种好网站制作成品下载
  • 沧州市网站江苏省网站备案电话号码
  • 可以做行程的网站网页公正流程
  • 一那个网站可以做一建题网络优化工作应该怎么做
  • 网站首页设计原则微信开放平台管理员怎么解除
  • 营销型网站建设集装箱液袋做宣传可以在哪些网站上发布
  • 小程序制作网站网站建设策划书主要内容
  • 惠州网站开发wordpress更换了域名
  • wordpress网站更新无线设置网站
  • 网站建设客户开发方法wordpress自动挣钱
  • 上海营销型网站建设团队wordpress cdn sae jquery
  • 网站手机端建设比较经典的营销案例
  • 网站维护与建设ppt网站开发软件dw
  • 自己做网站需不需要钱网站开发 icon
  • 子域名做微信开放平台网站应用家具设计大师
  • 安徽响应式网站推荐中国建筑劳务分包平台
  • 信用网站建设情况wordpress网站价格
  • 北京网站建设课程培训班网站开发进度安排