代码随想录——双指针/滑动窗口(二)

简介: 代码随想录——双指针/滑动窗口(二)

一.最长连续递增序列

  • go语言
func max(a,b int) int{
    if a>b{
        return a
    }
    return b
}
func findLengthOfLCIS(nums []int) int {
    n:=len(nums)
    maxlen:=0
    for l:=0;l<n;l++{
        r:=l+1
        for r<n&&nums[r]>nums[r-1]{
            r++
        }
        maxlen=max(r-l,maxlen)
    }
    return maxlen
}
  • cpp
int findLengthOfLCIS(vector<int>& nums) {
    int n = nums.size();
    int maxlen = 0;
    for (int l = 0; l < n; l++) {
        int r = l + 1;
        while (r < n && nums[r] > nums[r - 1]) {
            r++;
        }
        maxlen = max(r - l, maxlen);
    }
    return maxlen;
}

二.75. 颜色分类

  • go
func sortColors(nums []int)  {
    n:=len(nums)
    n0,n1:=0,0
    for i:=0;i<n;i++{
        num:=nums[i]
        nums[i]=2
        if num<2{
            nums[n1]=1
            n1++
        }
        if num<1{
            nums[n0]=0
            n0++
        }
    }
}
  • cpp
void sortColors(vector<int>& nums) {
    int n = nums.size();
    int n0 = 0, n1 = 0;
    for (int i = 0; i < n; i++) {
        int num = nums[i];
        nums[i] = 2;
        if (num < 2) {
            nums[n1++] = 1;
        }
        if (num < 1) {
            nums[n0++] = 0;
        }
    }
}

三. 904. 水果成篮

  • go
func max(a, b int) int {
  if a > b {
    return a
  }
  return b
}
func totalFruit(nums []int) int {
    cnt:=map[int]int{}
    maxlen:=0
    l:=0
    for r,x:=range(nums){
        cnt[x]++
        for len(cnt)>2{
            y:=nums[l]
            cnt[y]--
            if cnt[y]==0{
                delete(cnt,y)
            }
            l++
        }
        maxlen=max(maxlen,r-l+1)
    }
    return maxlen
}
  • cpp
class Solution {
public:
    int totalFruit(vector<int>& fruits) {
        unordered_map<int,int> map;
        int l=0;
        int maxlen=0;
        int n=fruits.size();
        for(int r=0;r<n;r++)
        {
            map[fruits[r]]++;
            while(map.size()>2)
            {
                auto y=map.find(fruits[l]);
                y->second--;
                if(y->second==0)
                {
                    map.erase(y);
                }
                l++;
            }
            maxlen=max(maxlen,r-l+1);
        }
        return maxlen;
    }
};



相关文章
|
8天前
|
Go C++
代码随想录——双指针与滑动窗口(四)
代码随想录——双指针与滑动窗口(四)
|
8天前
|
Go C++
代码随想录——双指针/滑动窗口(三)
代码随想录——双指针/滑动窗口(三)
|
8天前
代码随想录——双指针(一)
代码随想录——双指针(一)
|
22天前
|
算法
双指针+滑动窗口
双指针+滑动窗口
|
27天前
|
C语言
C语言指针带代码
C语言指针带代码
24 3
|
1月前
【错题集-编程题】dd爱框框(同向双指针 / 滑动窗口)
【错题集-编程题】dd爱框框(同向双指针 / 滑动窗口)
|
1月前
|
索引
LeetCode438题(无敌双指针——滑动窗口)
LeetCode438题(无敌双指针——滑动窗口)
|
1月前
|
C++
【C++】一文深入浅出带你参透库中的几种 [ 智能指针 ]及其背后实现原理(代码&图示)
【C++】一文深入浅出带你参透库中的几种 [ 智能指针 ]及其背后实现原理(代码&图示)
|
1月前
|
存储 算法
LeetCode刷题---209. 长度最小的子数组(双指针-滑动窗口)
LeetCode刷题---209. 长度最小的子数组(双指针-滑动窗口)
|
1月前
|
存储
【Leetcode 209】长度最小的子数组 —— 滑动窗口|双指针
我们可以使用双指针解决本题,定义两个指针 i 和 j 分别表示子数组(滑动窗口窗口)的开始位置和结束位置,维护变量 sum 存储子数组中的元素和。每一轮迭代中,每当 sum >= target 则记录子数组最小长度,移动慢指针。在每一轮迭代最后,移动快指针