同向双指针 滑动窗口【基础算法精讲 03】

长度最小的子数组 :

链接 :

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

思路 :

滑动窗口的思想,取i=j=0,向后遍历j,记录前缀和[l,r]为s,如果s>=target,那么左端点向右移动,直到s<target,维护一个[l,r]的滑动窗口,如此循环;

代码 :

Python :

python 复制代码
class Solution:
    def minSubArrayLen(self, target: int, nums: List[int]) -> int:
        n = len(nums)
        ans = n+1
        l=0
        s=0
        for r,x in enumerate(nums):
            s+=x
            while s>=target:
                ans = min(ans,r-l+1)
                s-=nums[l]
                l+=1
        return ans if ans <= n else 0

C++

cpp 复制代码
class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
       int n = nums.size();
       int i=0,j=0;
       long long sum = 0;
       int ans = INT_MAX;
       while(j<n){
           sum += nums[j];
           while(sum >= target){
               ans = min(ans,j-i+1);
               sum -= nums[i++];
           }
           j++;
       }
       return ans == INT_MAX ? 0 : ans;
    }
};

乘积小于K的子数组

链接 :

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

思想 :

滑动窗口,和上一题的思想一模一样;

对于一个区间[l,r],r固定,如果[l,r]的乘积小于k,那么对于整个区域满足乘积小于k的数量就是r-l+1个;

代码 :

python 复制代码
class Solution:
    def numSubarrayProductLessThanK(self, nums: List[int], k: int) -> int:
        if k<=1:
            return 0
        n = len(nums)
        ans = 0
        l = 0
        pf = 1
        for r,x in enumerate(nums):
            pf *= x
            while pf >= k:
                 pf /= nums[l]
                 l += 1
            ans += r - l + 1
        return ans

无重复元素的子串

链接 :

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

思路 :

双指针,哈希表

思路和前两题类似;

假设在一个无重复元素的字符串后面加上一个字符,如果出现重复元素,那么一定重复的是新加上的那个字符,那么设置一个hash表来统计次数,然后反复将窗口最前面的元素移出窗口,直到将前面与新加元素相同的元素移出时停止;然后循环更新答案即可;

代码 :

Python

python 复制代码
class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        l = 0
        cnt = Counter()
        ans = 0
        for r , c in enumerate(s):
            cnt[c]+=1
            while cnt[c]>=2:
                cnt[s[l]]-=1
                l+=1
            ans = max(ans,r-l+1)
        return ans

C++

cpp 复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
    unordered_map<char,int> hash;
    int ans=0;
    int n = s.size();
    int l=0;
    for(int r=0;r<n;r++){
        hash[s[r]]++;
        while(hash[s[r]] > 1) --hash[s[l++]];
        ans = max(ans,r-l+1);
    }
    return ans;
    }
};
相关推荐
杜杜的man14 分钟前
【go从零单排】迭代器(Iterators)
开发语言·算法·golang
小沈熬夜秃头中୧⍤⃝31 分钟前
【贪心算法】No.1---贪心算法(1)
算法·贪心算法
木向1 小时前
leetcode92:反转链表||
数据结构·c++·算法·leetcode·链表
阿阿越1 小时前
算法每日练 -- 双指针篇(持续更新中)
数据结构·c++·算法
skaiuijing1 小时前
Sparrow系列拓展篇:对调度层进行抽象并引入IPC机制信号量
c语言·算法·操作系统·调度算法·操作系统内核
Star Patrick2 小时前
算法训练(leetcode)二刷第十九天 | *39. 组合总和、*40. 组合总和 II、*131. 分割回文串
python·算法·leetcode
武子康3 小时前
大数据-214 数据挖掘 机器学习理论 - KMeans Python 实现 算法验证 sklearn n_clusters labels
大数据·人工智能·python·深度学习·算法·机器学习·数据挖掘
m0_571957586 小时前
Java | Leetcode Java题解之第543题二叉树的直径
java·leetcode·题解
pianmian18 小时前
python数据结构基础(7)
数据结构·算法
好奇龙猫10 小时前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法