【leetcode hot 100 560】和为K的子数组

解法一:用左右指针寻找字串,如果和>k,则减少一个数(left++);如果和<k,则加上一个数(right++)。

java 复制代码
class Solution {
    public int subarraySum(int[] nums, int k) {
        int num = 0;
        int left=0, right=0;
        while(left<nums.length && right<nums.length && left<=right){
            int sum = 0;
            for(int i=left; i<=right; i++){
                sum += nums[i];
            }
            if(sum==k){
                num++;
                if(left==right){
                    // nums[i]=k
                    right++;
                }else{
                    left=right;
                }
            }else if(sum>k){// 不适合含有复数的判断
                left++;
                right = Math.max(left,right);
            }else{
                right++;
            }
        }
        return num;
    }
}

错误原因:该方法不适合于nums有负数的情况

方法二:(枚举)循环i寻找[0, i]中子串和为k的子串。

java 复制代码
public class Solution {
    public int subarraySum(int[] nums, int k) {
        int num=0;
        for(int i=0; i<nums.length; i++){
            int sum=0;
            for(int j=i; j>=0; j--){
                sum += nums[j];
                if(sum==k){
                    num++;
                }
            }
        }
        return num;
    }
}
相关推荐
a cool fish(无名)2 分钟前
8.1-使用向量存储值列表
人工智能·python·算法
茴香豆的茴113 分钟前
转码刷 LeetCode 笔记[1]:3.无重复字符的最长子串(python)
笔记·算法·leetcode
美团技术团队14 分钟前
ACL 2025 | 美团技术团队论文精选
人工智能·算法
xnglan29 分钟前
数据结构与算法:队列的表示和操作的实现
c语言·数据结构·算法·链表
快去睡觉~29 分钟前
力扣46:全排列
算法·leetcode·动态规划
蒋星熠32 分钟前
字母异位词分组(每天刷力扣hot100系列)
开发语言·c++·算法·leetcode·职场和发展
FirstFrost --sy39 分钟前
数据结构之排序
c语言·数据结构·算法·排序算法
竹子_2343 分钟前
《零基础入门AI:传统机器学习核心算法(决策树、随机森林与线性回归)》
人工智能·算法·机器学习
Darkwanderor44 分钟前
哈希相关的模拟实现
数据结构·c++·算法·哈希算法
阑梦清川1 小时前
树的存储方式--vector容器和链式前向星
算法