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

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

一.最长连续递增序列

  • 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;
    }
};



相关文章
|
3月前
|
存储 搜索推荐 C语言
深入C语言指针,使代码更加灵活(二)
深入C语言指针,使代码更加灵活(二)
|
3月前
|
存储 程序员 编译器
深入C语言指针,使代码更加灵活(一)
深入C语言指针,使代码更加灵活(一)
|
3月前
|
C语言
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
|
5月前
|
存储 大数据 测试技术
掌握 GoLang 中的指针:高效代码的提示和技巧
掌握 GoLang 中的指针:高效代码的提示和技巧
|
7月前
代码随想录——双指针(一)
代码随想录——双指针(一)
|
7月前
|
算法
双指针+滑动窗口
双指针+滑动窗口
|
7月前
|
Go C++
代码随想录——双指针与滑动窗口(四)
代码随想录——双指针与滑动窗口(四)
|
7月前
|
Go C++
代码随想录——双指针/滑动窗口(三)
代码随想录——双指针/滑动窗口(三)
|
2月前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
191 13
|
3月前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
46 0