【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;
    }
}
相关推荐
董董灿是个攻城狮2 小时前
5分钟搞懂什么是窗口注意力?
算法
Dann Hiroaki2 小时前
笔记分享: 哈尔滨工业大学CS31002编译原理——02. 语法分析
笔记·算法
qqxhb4 小时前
零基础数据结构与算法——第四章:基础算法-排序(上)
java·数据结构·算法·冒泡·插入·选择
FirstFrost --sy6 小时前
数据结构之二叉树
c语言·数据结构·c++·算法·链表·深度优先·广度优先
森焱森6 小时前
垂起固定翼无人机介绍
c语言·单片机·算法·架构·无人机
搂鱼1145146 小时前
(倍增)洛谷 P1613 跑路/P4155 国旗计划
算法
Yingye Zhu(HPXXZYY)6 小时前
Codeforces 2021 C Those Who Are With Us
数据结构·c++·算法
独行soc7 小时前
2025年渗透测试面试题总结-2025年HW(护网面试) 33(题目+回答)
linux·科技·安全·网络安全·面试·职场和发展·护网
无聊的小坏坏8 小时前
三种方法详解最长回文子串问题
c++·算法·回文串
长路 ㅤ   8 小时前
Java后端技术博客汇总文档
分布式·算法·技术分享·编程学习·java后端