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

海口网站建设百度在线

海口网站建设,百度在线,给企业做网站运营,网站首页建设图文教程给你一个整数数组 nums 和一个整数 k ,编写一个函数来判断该数组是否含有同时满足下述条件的连续子数组:子数组大小 至少为 2 ,且子数组元素总和为 k 的倍数。如果存在,返回 true ;否则,返回 false 。如果存…

给你一个整数数组 nums 和一个整数 k ,编写一个函数来判断该数组是否含有同时满足下述条件的连续子数组:

  • 子数组大小 至少为 2 ,且

  • 子数组元素总和为 k 的倍数。

如果存在,返回 true ;否则,返回 false

如果存在一个整数 n ,令整数 x 符合 x = n * k ,则称 xk 的一个倍数。0 始终视为 k 的一个倍数。

示例 1:

输入:nums = [23,2,4,6,7], k = 6

输出:true

解释:[2,4] 是一个大小为 2 的子数组,并且和为 6 。

示例 2:

输入:nums = [23,2,6,4,7], k = 6

输出:true

解释:[23, 2, 6, 4, 7] 是大小为 5 的子数组,并且和为 42 。

42 是 6 的倍数,因为 42 = 7 * 6 且 7 是一个整数。

示例 3:

输入:nums = [23,2,6,4,7], k = 13

输出:false

523. 连续的子数组和 - 力扣(Leetcode)

思路

定义前缀和 数组 preSum, preSum[ i ] 表示 nums[0, ..., i] 的和,若是有子数组 nums[i, ..., j] 和是 k的倍数,那么有 ( preSum[j] - preSum[i] ) % k == 0 ,即两者除以k后的余数是相等的。 preSum[j] % k == preSum[i] % k。
我们定义一个 map, key为当前前缀和的余数,即 key = preSum[i] % k
若是有前缀和preSum[j] % k == preSum[i] % k 且 j - i >= 2 ,说明存在子数组 nums[i+1,..., j] 的和为 k的倍数。
这里要考虑一下特殊情况,当preSum[i] % k == 0 ,即前缀和nums[0, ..., i] 本身就是 k的倍数,若是 i >=1 即子数组的长度大于等于 2

c++

class Solution {
public:vector<int> preSum;map<int, vector<int>> targetMap; // key is preSum[ i ]%k, value is ibool checkSubarraySum(vector<int>& nums, int k) {preSum = vector<int>(nums.size(), 0);for(int i = 0; i < nums.size(); i++) {if(i == 0) {preSum[i] = nums[i];} else {preSum[i] = preSum[i-1] + nums[i];}int key = preSum[i] % k;if(key == 0 && i>=1) { // 若是从下标 0 开始的前缀和 preSum[i] 满足是 k的倍数且子数组长度大于2,那么题目中要求的子数组我们是可以满足的,子数组就是 nums[0, ..., i]return true;}if(targetMap.count(key)) {for(auto v:targetMap[key]) {if(i-v>=2) {return true;} else {targetMap[key].push_back(i);}}} else {vector<int> vec;vec.push_back(i);targetMap[key] = vec;}}return false;}
};
http://www.dt0577.cn/news/30686.html

相关文章:

  • 晋中建设局网站2022年适合小学生的新闻
  • cms 网站后台百度投放平台
  • 备案信息如何上传的网站上微信营销策略有哪些
  • 婚纱摄影网站设计88个seo网站优化基础知识点
  • 网站建设总结与河南关键词优化搜索
  • 青岛网站建设网络营销和直播电商专业学什么
  • 备案名称和网站logo不一致标题seo是什么意思
  • 武汉手机网站建设公司seo外链怎么发
  • 福州 网站开发公司免费b站推广软件
  • 做直播导航网站有哪些恶意点击广告软件
  • 开发软件的应用系统优化是什么意思
  • 腾讯云网站免费建设惠州seo报价
  • 做缓网站阿里云域名查询
  • 五星级酒店网站建设开网站怎么开
  • 怎么做网站模板百度营销登录
  • 河北网站搜索排名优化方案seo网站排名软件
  • 上海高端网站建设服务公湖南seo推广系统
  • 中国免费最好用建站cms时事新闻最新2022
  • 医疗网站建设行业现状如何制作网站赚钱
  • 衡南网站建设大数据营销案例
  • 专门做面条菜谱的网站深圳网页搜索排名提升
  • 北京室内设计公司前十名优化关键词快速排名
  • 自己注册网站要多少钱成都网络营销推广公司
  • 网站建设扌首选金手指网络营销的方式有十种
  • 西安企业建站排名沈阳seo网站关键词优化
  • 在iis上部署的网站本机无法浏览解决方法新媒体运营主要做什么
  • 网站建设计入什么科目深圳网络推广方法
  • 什么网站能赚钱百度指数的作用
  • 哪个女装网站做的好太原百度快速优化排名
  • 汽车网站建设公司哪家好海外推广方法有哪些