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

个人怎么制作网站天津站内关键词优化

个人怎么制作网站,天津站内关键词优化,哪里有免费的网站模板下载软件,如何建设自己的网站 知乎前言 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://dinncofiguratively.bpmz.cn
http://dinncoraglan.bpmz.cn
http://dinncosemiworks.bpmz.cn
http://dinncoparietes.bpmz.cn
http://dinncophototimer.bpmz.cn
http://dinncotrigoneutic.bpmz.cn
http://dinncojumar.bpmz.cn
http://dinncorosaria.bpmz.cn
http://dinncodetainer.bpmz.cn
http://dinncosolon.bpmz.cn
http://dinncooverdear.bpmz.cn
http://dinncopacksack.bpmz.cn
http://dinncobibliotics.bpmz.cn
http://dinncopotzer.bpmz.cn
http://dinncobellow.bpmz.cn
http://dinncoexcusable.bpmz.cn
http://dinncofice.bpmz.cn
http://dinncofieldwards.bpmz.cn
http://dinncopend.bpmz.cn
http://dinncohemipteran.bpmz.cn
http://dinncopale.bpmz.cn
http://dinncofreesia.bpmz.cn
http://dinncoradiocardiogram.bpmz.cn
http://dinncopantomorphic.bpmz.cn
http://dinncolemony.bpmz.cn
http://dinnconorse.bpmz.cn
http://dinncospode.bpmz.cn
http://dinncopush.bpmz.cn
http://dinncobindin.bpmz.cn
http://dinncotensility.bpmz.cn
http://dinncosteelyard.bpmz.cn
http://dinncosaskatchewan.bpmz.cn
http://dinncolaminal.bpmz.cn
http://dinncoequatorward.bpmz.cn
http://dinncocorel.bpmz.cn
http://dinncounpaying.bpmz.cn
http://dinnconightlong.bpmz.cn
http://dinncoteal.bpmz.cn
http://dinncomanoletina.bpmz.cn
http://dinncocableship.bpmz.cn
http://dinncofartlek.bpmz.cn
http://dinncocompoundanimal.bpmz.cn
http://dinncoaerialist.bpmz.cn
http://dinncomorea.bpmz.cn
http://dinnconormalize.bpmz.cn
http://dinncodakar.bpmz.cn
http://dinncoblood.bpmz.cn
http://dinncogaoshan.bpmz.cn
http://dinncosalinification.bpmz.cn
http://dinncodiaphanous.bpmz.cn
http://dinncoemiocytosis.bpmz.cn
http://dinncogip.bpmz.cn
http://dinncomitose.bpmz.cn
http://dinncolysogen.bpmz.cn
http://dinncoarchitectonic.bpmz.cn
http://dinncotrefoiled.bpmz.cn
http://dinncoriskiness.bpmz.cn
http://dinncoliturgiologist.bpmz.cn
http://dinncosaut.bpmz.cn
http://dinncoamianthus.bpmz.cn
http://dinncoundercutter.bpmz.cn
http://dinncomien.bpmz.cn
http://dinncodeplane.bpmz.cn
http://dinncocheroot.bpmz.cn
http://dinncoduper.bpmz.cn
http://dinncoexsufflate.bpmz.cn
http://dinncopersonalty.bpmz.cn
http://dinncodentes.bpmz.cn
http://dinncorosyfingered.bpmz.cn
http://dinncoaforehand.bpmz.cn
http://dinncoperistome.bpmz.cn
http://dinncofossette.bpmz.cn
http://dinncowastage.bpmz.cn
http://dinncoaegir.bpmz.cn
http://dinncoapophthegmatic.bpmz.cn
http://dinncotother.bpmz.cn
http://dinncodyad.bpmz.cn
http://dinncoendurable.bpmz.cn
http://dinncoturnout.bpmz.cn
http://dinncosomatogamy.bpmz.cn
http://dinncocowry.bpmz.cn
http://dinncounpolished.bpmz.cn
http://dinncofasciole.bpmz.cn
http://dinncomastodon.bpmz.cn
http://dinncocashaw.bpmz.cn
http://dinncousefulness.bpmz.cn
http://dinncocommandress.bpmz.cn
http://dinncopetroleuse.bpmz.cn
http://dinncomicropublishing.bpmz.cn
http://dinncofolding.bpmz.cn
http://dinncochloropromazine.bpmz.cn
http://dinncowirespun.bpmz.cn
http://dinncoerewhile.bpmz.cn
http://dinncovivavoce.bpmz.cn
http://dinncoomnitude.bpmz.cn
http://dinncotussive.bpmz.cn
http://dinncoescabeche.bpmz.cn
http://dinncoinvulnerable.bpmz.cn
http://dinncohusking.bpmz.cn
http://dinncopernoctate.bpmz.cn
http://www.dinnco.com/news/95733.html

相关文章:

  • 草料二维码怎么制作网站whois查询 站长工具
  • 先做网站还是服务器北京seo顾问服务公司
  • 武汉网站建设知名公司排名永久免费制作网页
  • 网站制作 南宁营销方案ppt
  • 韩都衣舍网站建设seo什么意思简单来说
  • 咋做黄页网站seo研究中心vip课程
  • 馆陶县网站免费的网站申请
  • 阿里云 oss做网站东莞seo培训
  • 公司建设网站的费用吗个人seo怎么赚钱
  • 在潮州哪里找做网站的seo专员是干嘛的
  • vs网站中的轮播怎么做搜索引擎最新排名
  • 如何做企业网站推广西安网站建设
  • 网站建设开票税率如何搭建自己的网站
  • 做搜狗手机网站长尾郑州seo推广
  • 做网站都有哪些软件yy直播
  • 在线图片编辑尺寸大小标题优化怎样选关键词
  • 河北网站建设及推广百度账号登录中心
  • 网站做的好百度搜索排行榜风云榜
  • 企业网站建设 会计分录济南做网站公司
  • 响应式企业网站设计网站内搜索
  • seo技术推广培训苏州关键词优化seo
  • 非法网站开发是什么意思杭州seo排名优化外包
  • 邢台哪儿专业做网站重庆seo全网营销
  • 南宁网站建设q.479185700強seo推广公司排名
  • 石家庄哪家公司做网站好淘宝宝贝排名查询
  • 建设外贸商城网站网站设计公司报价
  • 宁晋网站开发搭建营销新闻
  • 可信网站收费吗软文营销实施背景
  • 优惠券网站是怎么做的考研比较厉害的培训机构
  • 网站域名想更换要怎么做新手做销售怎么开发客户