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

想做网站找哪个公司好专门做设计的网站有哪些

想做网站找哪个公司好,专门做设计的网站有哪些,网站域名的安全性,ico网站图标题目链接 Leetcode.560 和为 K 的子数组 mid 题目描述 给你一个整数数组 n u m s nums nums 和一个整数 k k k ,请你统计并返回 该数组中和为 k k k 的子数组的个数 。 子数组是数组中元素的连续非空序列。 示例 1: 输入:nums [1,1,1]…

题目链接

Leetcode.560 和为 K 的子数组 mid

题目描述

给你一个整数数组 n u m s nums nums 和一个整数 k k k ,请你统计并返回 该数组中和为 k k k 的子数组的个数

子数组是数组中元素的连续非空序列。

示例 1:

输入:nums = [1,1,1], k = 2
输出:2

示例 2:

输入:nums = [1,2,3], k = 3
输出:2

提示:
  • 1 ≤ n u m s . l e n g t h ≤ 2 ∗ 1 0 4 1 \leq nums.length \leq 2 * 10^4 1nums.length2104
  • − 1000 ≤ n u m s [ i ] ≤ 1000 -1000 \leq nums[i] \leq 1000 1000nums[i]1000
  • − 1 0 7 ≤ k ≤ 1 0 7 -10^7 \leq k \leq 10^7 107k107

解法:前缀和 + 哈希表

我们假设 [ 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 ] = k nums[j] + nums[j + 1] + ... + nums[i-1] + nums[i] = k nums[j]+nums[j+1]+...+nums[i1]+nums[i]=k

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

s u m [ i ] − s u m [ j − 1 ] = k sum[i] - sum[j-1] = k sum[i]sum[j1]=k

再转换一下得到:

s u m [ j − 1 ] = s u m [ i ] − k sum[j-1] = sum[i] - k sum[j1]=sum[i]k

那么以 n u m s [ i ] nums[i] nums[i] 为结尾的数组,我们只需要统计前面等于 s u m [ j − 1 ] sum[j-1] sum[j1] 也就是 s u m [ i ] − k sum[i] - k sum[i]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}

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

C++代码:

class Solution {
public:int subarraySum(vector<int>& nums, int k) {int n = nums.size() , ans = 0 , sum = 0;unordered_map<int,int> cnt;cnt[0] = 1;for(int i = 0;i < n;i++){sum += nums[i];ans += cnt[sum - k];cnt[sum]++;}return ans;}
};
http://www.yayakq.cn/news/340361/

相关文章:

  • 做长老环的网站金融企业类网站模板
  • 鸭梨网站建设图门市建设局网站
  • 做网页兼职网站开发一个外卖app需要多少钱
  • 动力网站建设网站后台打不开了怎么办
  • 哈尔滨自助建站郑州市发布
  • 邯郸网站制作找谁筑成建设集团网站
  • seo品牌优化百度资源网站推广关键词排名门户类网站什么意思简单
  • 基于无网站网络营销的问题福州网站开发
  • 佛山新网站建设市场互助平台网站建设
  • 新手学做网站 pdf公司怎么建设网站首页
  • 揭阳网站制作怎样湛江做网站建设
  • 做网站的叫什么学技术网站
  • 品牌网站建设小7蝌蚪高淳seo外包公司
  • win7云主机怎么做网站优秀ppt作品范例
  • 怎样建网站宣传产品个人网站如何获得流量
  • 九度企业网站推广软件企业展示网站开发
  • 如何做网站alexa排名互联网公司排名 中国
  • wordpress管理网站360免费建站永久免费
  • wordpress 音乐站博客网站建设方案书
  • 用织梦做的网站下载地址景安免费虚拟主机
  • 低价网站建设浩森宇特个人网页设计实训报告
  • 做淘宝客网站详细步骤施工企业质量管理应遵循的原则
  • 网站仿制教程吸引客流的25个技巧
  • 西丽网站设计建立网站的申请
  • 网站备案 接入商域名注册哪个网站便宜
  • 手机怎么做3d短视频网站建设校园门户网站方案
  • app网站如何做推广旅游app界面设计
  • 网站建设保障方案87网站一起做
  • 开发网站多少钱一个月泰安网红打卡景点
  • 创建网站需要什么平台小工具文本wordpress