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

设计单网站建设seo高端培训

设计单网站建设,seo高端培训,wordpress 用户id,百度做网站骗人到哪里去投诉题目: 给定一个整数数组 nums 和一个整数 k ,返回其中元素之和可被 k 整除的(连续、非空) 子数组 的数目。 子数组 是数组的 连续 部分。 示例 1: 输入:nums [4,5,0,-2,-3,1], k 5 输出:7 …

题目:

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

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

示例 1:

输入:nums = [4,5,0,-2,-3,1], k = 5
输出:7
解释:
有 7 个子数组满足其元素之和可被 k = 5 整除:
[4, 5, 0, -2, -3, 1], [5], [5, 0], [5, 0, -2, -3], [0], [0, -2, -3], [-2, -3]

示例 2:

输入: nums = [5], k = 9
输出: 0

提示:

  • 1 <= nums.length <= 3 * 104
  • -104 <= nums[i] <= 104
  • 2 <= k <= 104

算法原理:

本题所需前置知识:

1 同余定理

如果 (a - b) % n == 0 ,那么可以得到⼀个结论: a % n == b % n 。即如果两个数相减的差能被n整除,那么这两个数对n取模的结果相同

如  (26 - 2) % 12 == 0 那么 26 % 12 == 2 % 12 == 2
 

2 c++ 中负数取模结果的修正:
 

c++ 中关于负数的取模运算,结果是「把负数当成正数,取模之后的结果加上⼀个负号」

如 -1 % 3 = -(1 % 3) = -1

由于余数在接下来的代码中会充当下标,所以余数不能为负数,故而有修正余数的情况:

(a % n + n) % n  

若是a%n的结果为负数,那么+n就会是正数,当然若是a%n的结果本身就是正数,那么+n就改变了,故而%n

当a%n的结果为负数,修正后依然比n小,故而%n不会发生改变

当a%n的结果为正数,无需修正,但+n使得结果变了,又%n,让变了的结果变回原样

 

枚举所有子数组可以每次固定一个起始位置向后枚举,我们当然也可以每次固定一个结尾位置向前枚举

i是任意位置,那么以 i 为结尾的和可被k 整除的子数组个数就可以这么求:

由图示,我们知道要求[0,i]区间内绿线的个数,只要知道红线的个数即前缀和为x的个数就可以了,又sum%k==x%k

那么我们只需要知道在[0,i-1]内,前缀和(即x)%k==sum%k的个数即可

hash表统计前缀和%k的余数出现的次数

细节问题:hash[0] = 1 ,当i位置的前缀和本身sum就是能被k整除的,[0,i]区间本身就是一个合法子数组,那么x=0

代码实现:

class Solution 
{
public:int subarraysDivByK(vector<int>& nums, int k) {unordered_map<int,int> hash;hash[0] = 1;//0这个数(这个前缀和)的余数,也可以写成hash[0%k]=1int ret = 0;int sum = 0;for(auto e:nums){sum+=e;//当前位置的前缀和int r = (sum%k+k)%k;//修正后的余数if(hash.count(r)){ret+=hash[r];}hash[r]++;}return ret;}
};

http://www.mnyf.cn/news/34639.html

相关文章:

  • 一个好的网站内页大概做多少高端网站建设报价
  • 个人业务网站创建怎么下载百度
  • 天津国际工程建设监理公司网站网络营销策划方案论文
  • 手机能建设网站忙a站
  • 中国建设网站跨境电商平台排行榜前十名
  • 无锡哪家网站做的比较好百度有什么办法刷排名
  • 网站建设时间查询搜索引擎优化面对哪些困境
  • 西安微信网站建设公司朝阳seo排名优化培训
  • 表白网站制作软件南京百度seo排名
  • 网络营销的网站建设软文代写公司
  • 网站建设管理 优帮云怎么做宣传推广
  • 买域名送网站湘潭网站设计外包服务
  • 企业网站建设市场前景网站建设哪家公司好
  • 惠州最专业的网站建设公司手机百度seo怎么优化
  • 营销型企业网站怎么制作西安网站制作公司
  • 电商平台排名100强seo推广排名重要吗
  • 赌球网站如何做代理b站怎么推广
  • 5g网络优化工程师seo门户网站建设方案
  • 织梦绑定网站出现错误互联网推广员是做什么
  • 北京做网站建设的公司排名用今日头条导入自己网站外链
  • 织梦是怎么做网站合肥seo招聘
  • 百度只更新快照不收录网站广州发布紧急通知
  • 深圳外贸电商网站建设百度权重批量查询
  • 外卖在家做咋上网站宁德市蕉城区疫情
  • 永兴集团网站淮安网站seo
  • access数据库做网站seo工具不包括
  • 怎样做批发网站可以推广网站
  • 天天爱天天做网站14个seo小技巧
  • 周口网站建设费用网站排名优化培训电话
  • 上海松江做网站的公司html制作网站