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

php建站系统哪个好上海搜索引擎关键词优化

php建站系统哪个好,上海搜索引擎关键词优化,安徽建设监理协会网站,外包app题目链接 Leetcode.974 和可被 K 整除的子数组 rating : 1676 题目描述 给定一个整数数组 n u m s nums nums 和一个整数 k k k ,返回其中元素之和可被 k k k 整除的(连续、非空) 子数组 的数目。 子数组 是数组的 连续 部分。 示例 1&…

题目链接

Leetcode.974 和可被 K 整除的子数组 rating : 1676

题目描述

给定一个整数数组 n u m s nums nums 和一个整数 k k k ,返回其中元素之和可被 k 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 ≤ n u m s . l e n g t h ≤ 3 ∗ 1 0 4 1 \leq nums.length \leq 3 * 10^4 1nums.length3104
  • − 1 0 4 ≤ n u m s [ i ] ≤ 1 0 4 -10^4 \leq nums[i] \leq 10^4 104nums[i]104
  • 2 ≤ k ≤ 1 0 4 2 \leq k \leq 10^4 2k104

解法:前缀和 + 哈希表

我们假设 [ j , i ] [j,i] [j,i] 区间的子数组元素和可以被 k k k 整除,即 :

( n u m s [ j ] + n u m s [ j + 1 ] + . . . + n u m s [ i − 1 ] + n u m s [ i ] ) m o d k = 0 (nums[j] + nums[j + 1] + ... + nums[i-1] + nums[i])\ mod\ k = 0 (nums[j]+nums[j+1]+...+nums[i1]+nums[i]) mod k=0

我们用 s u m sum sum 表示 n u m s nums nums 的前缀和数组,可将上式转换为:

( s u m [ i ] − s u m [ j − 1 ] ) m o d k = 0 (sum[i] - sum[j-1])\ mod\ k = 0 (sum[i]sum[j1]) mod k=0

再转换一下得到:

s u m [ j − 1 ] m o d k = s u m [ i ] m o d k sum[j-1]\ mod\ k= sum[i]\ mod\ k sum[j1] mod k=sum[i] mod k

那么以 n u m s [ i ] nums[i] nums[i] 为结尾的数组,我们只需要统计前面等于 s u m [ j − 1 ] m o d k sum[j-1]\ mod\ k sum[j1] mod k 也就是 s u m [ i ] m o d k sum[i]\ mod\ k sum[i] mod k 的数量 t t t 即可。

那么这个 t t t 就是以 n u m s [ i ] nums[i] nums[i] 为结尾的数组中 和能被 k k k 整除的子数组的数量。

我们只需要对每一个 n u m s [ i ] nums[i] nums[i] 都加上 t t t 即可,这样我们就可以统计出所有的 和能被 k k k 整除的子数组的数量。

在实现上,我们使用哈希表来记录前缀和出现的次数。初始时,和为 0 0 0 ,也需要统计它的出现次数,即 { 0 , 1 } \{ 0 , 1 \} {0,1}

注意:由于 n u m s nums nums 中存在负数,所以 s u m m o d k sum\ mod\ k sum mod k 仍然有可能是负数,所以我们要将其转换为正数,即:

k e y = ( s u m m o d k + k ) m o d k key = (sum\ mod\ k + k)\ mod\ k key=(sum mod k+k) mod k

时间复杂度: O ( n ) O(n) O(n)

C++代码:

class Solution {
public:int subarraysDivByK(vector<int>& nums, int k) {int n = nums.size();int ans = 0 , sum = 0;unordered_map<int,int> cnt{{0,1}};for(int i = 0;i < n;i++){sum += nums[i];auto key = (sum % k + k) % k;ans += cnt[key];cnt[key]++;}return ans;}
};
http://www.ds6.com.cn/news/114468.html

相关文章:

  • php做学校网站免费下载磁力链最佳的搜索引擎
  • 武汉网站建设培训班创新驱动发展战略
  • 网站建设需要哪些软件网站推广系统
  • 网站项目建设申请汇报大纲黄冈便宜的网站推广怎么做
  • 可以做微信推文的网站做网站找哪个公司好
  • wordpress拖动建站南宁最新消息今天
  • 赣州网站制作公司手机制作网站的软件
  • 赵公口网站建设北京网站设计百度公司简介
  • 阿里云域名如何做网站花关键词排名系统
  • 教育网站制作视频360搜索推广
  • 广州天河网站开发公司营销策略包括哪些内容
  • wordpress版权所有在哪里搜索引擎优化的例子
  • 网站上动画视频怎么做泉州seo代理商
  • 岳阳建网站google翻译
  • 美国做电商网站有哪些网络营销的分类
  • 网站哪个服务器好外链代发免费
  • 专业网站建设方案站长工具同大全站
  • 服务器在国外的网站网页设计期末作业模板
  • wordpress 微博时间如何优化关键词提升相关度
  • 做网站却不给客户源代码厦门百度公司
  • qq群优惠券里面网站怎么做的站长统计推荐
  • 万网网站备案seo网站关键词优化方式
  • 网站怎么做利于优化讯展网站优化推广
  • 网站营销推广如何做周口网站建设公司
  • 烟台专业网站建设广告推广平台代理
  • 网站做现金抽奖 能通过天津网络推广seo
  • 太原做学校网站的公司网图识别在线百度
  • dy业务低价自助下单平台网站友情链接交换条件
  • 关键词是在网站后台做的吗如何推广小程序
  • 柳州企业网站建设搜索引擎调价工具哪个好