优选算法——滑动窗口

优选算法——滑动窗口

优选算法——滑动窗口

1.长度最小的子数组

在这里插入图片描述

解题原理

在这里插入图片描述

📋 解题步骤

第一步:理解题意

  • 找一个连续子数组,使其和 ≥ target,且长度最小
  • 数组元素都是正整数(关键性质)
  • 无解返回 0

第二步:分析暴力解法

  • 枚举所有子数组:O(n²) 或 O(n³)
  • 对于 n = 10⁵ 会超时

第三步:寻找优化点

  • 正整数 → 窗口扩展时和单调递增
  • 可以用滑动窗口优化

第四步:设计滑动窗口

遍历右指针: 扩展窗口 从右边进窗口 判断: 如果 sum >= target: 更新最小长度 收缩窗口 从左边出窗口 

第五步:手动模拟

步骤leftright窗口sumresult
403[2,3,1,2]84
724[1,2,4]73
1045[4,3]72

第六步:编写代码

classSolution{public:intminSubArrayLen(int target, vector<int>& nums){int len=INT_MAX;int n=nums.size();int sum=0;for(int left=0,right=0;right<n;right++){ sum+=nums[right];//进窗口while(sum>=target)//判断{ len=min(len,right-left+1); sum-=nums[left++];}}return len==INT_MAX?0:len;}};

第七步:验证边界

  • 单元素、无解、总和不足等情况

第八步:复杂度

  • 时间:O(n)
  • 空间:O(1)

2. 无重复字符的最长子串

在这里插入图片描述

题目信息

  • 题目:LCR 016. 无重复字符的最长子串(与主站第3题相同)
  • 难度:中等
  • 标签:哈希表、字符串、滑动窗口

解法总结

方法时间复杂度空间复杂度
集合O(n)O(min(n, 128))
哈希表O(n)O(min(n, 128))
数组(推荐)O(n)O(1)

核心思路

滑动窗口法

  1. 用双指针维护一个无重复字符的窗口
  2. 用哈希表/数组记录每个字符最后出现的位置

遇到重复字符时,左指针直接跳到重复字符的下一个位置

在这里插入图片描述

代码示例(C++ 最优解)

classSolution{public:intlengthOfLongestSubstring(string s){int hash[128]={0};int ret=0;int n=s.size();for(int left=0,right=0;right<n;right++){ hash[s[right]]++;//进窗口while(hash[s[right]]>1)//判断{ hash[s[left++]]--;//出窗口} ret=max(ret,right-left+1);}return ret;}}; hash[s[left++]]--;//出窗口} ret=max(ret,right-left+1);}return ret;}};

Read more

Java 单元测试自动化:手把手教你用 Claude Skills 生成高质量测试代码

Java 单元测试自动化:手把手教你用 Claude Skills 生成高质量测试代码 * 前言 * 一、什么是 Claude Skills? * 1.1 核心概念 * 1.2 为什么需要 Skill? * 二、创建 Java 单元测试 Skill * 2.1 准备工作 * 2.2 编写 SKILL.md * YAML 元数据 * 主体内容结构 * 2.3 核心:触发条件与前置检查 * 触发条件定义 * 前置检查清单 * 三、测试代码生成规范详解 * 3.1 测试类命名规范 * 3.2 导入声明规范 * 3.3

By Ne0inhk
Java:二维数组

Java:二维数组

目录 1. 二维数组的基础格式 1.1 二维数组变量的创建 —— 3种形式 1.2 二维数组的初始化 \1 动态初始化 \2 静态初始化 2. 二维数组的大小 和 内存分配 3. 二维数组的不规则初始化 4. 遍历二维数组 4.1 for循环 编辑 4.2 for-each循环 5. 二维数组 与 方法 5.1 二维数组的数据类型 5.2 二维数组作为方法参数 5.3 二维数组作为返回值 6. 二维数组转字符串deepToString 1. 二维数组的基础格式 1.1 二维数组变量的创建 —— 3种形式

By Ne0inhk
Java 位运算算法题目练习

Java 位运算算法题目练习

位运算 * 汉明距离 * 比特位计数 * 只出现一次的数字 * 只出现一次的数字||| * 判断字符是否唯一 * 丢失的数字 * 两数之和 * 只出现一次的数字 * 消失的两个数字 汉明距离 题目解析:判断两个数的对应的二进制位不同的个数 直接判断(x>>i)&1 和 (y>>i)&1,先获取对应二进制位,在判断是否相等即可 classSolution{publicinthammingDistance(int x,int y){int count =0;//从后向前依次取出二进制位,进行比较for(int i =0;i <31;i++){if(((x>

By Ne0inhk