代码随想录——双指针与滑动窗口(四)

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

一.1423. 可获得的最大点数

题目详情

解题思路

这里我们每次只能取最左或最右边的卡牌,第一反应其实是使用双指针,通过局部贪心来解决,但是如果两边相等的话用局部贪心无法来判断到底取哪一边,那我们不妨换一个思路:

我们首先任选一边维持一个长度为k的子数组,计算出子数组的和,记录下来为当前最大值,然后定义左右指针,删去左指针指向的值,加上右指针指向的值,不断更新当前最大值,当左指针的位置到-1,当前最大值就是目标值。

解题代码:

  • Go
func max(a,b int)int{
    if a>b{
        return a
    }else{
        return b
    }
}
func maxScore(cardPoints []int, k int) int {
    if k==0{
        return 0
    }
    n:=len(cardPoints)
    l,r:=0,n-1
    res:=0
    for l<k{
        res+=cardPoints[l]
        l++
    }
    l=k-1
    maxvalue:=res
    for l>=0{
        res-=cardPoints[l]
        res+=cardPoints[r]
        l--
        r--
        maxvalue=max(maxvalue,res)
    }
    return maxvalue
}
  • Cpp
class Solution {
public:
    int max(int a, int b) {
        return a > b ? a : b;
    }
    int maxScore(std::vector<int>& cardPoints, int k) {
        if (k == 0) {
            return 0;
        }
        int n = cardPoints.size();
        int l = 0, r = n - 1;
        int res = 0;
        for (l = 0; l < k; l++) {
            res += cardPoints[l];
        }
        l = k - 1;
        int maxvalue = res;
        while (l >= 0) {
            res -= cardPoints[l];
            res += cardPoints[r];
            l--;
            r--;
            maxvalue = max(maxvalue, res);
        }
        return maxvalue;
    }
};

二.1456. 定长子串中元音的最大数目

题目详情

解题思路

这道题属于一个比较典型的滑动窗口题目了,我们维护一个定长的滑动窗口,记录里面的元音字母数即可。

代码

  • Go
func in (s rune) bool{
    if s=='a'||s=='o'||s=='e'||s=='i'||s=='u'{
        return true
    }else{
        return false
    }
}
func max(a,b int)int{
    if a>b{
        return a
    }else{
        return b
    }
}
func maxVowels(s string, k int) int {
   n:=len(s)
   l:=0
   maxvalue:=0
   sum:=0
   for r:=0;r<n;r++{
    if in(rune(s[r])){
        sum++
    }
    if r-l+1>k{
        if in(rune(s[l])){
            sum--
        }
        l++
    }
    maxvalue=max(maxvalue,sum)
   }
   return maxvalue
    
}
  • Cpp
class VowelCounter {
public:
    bool isVowel(char s) {
        if (s == 'a' || s == 'o' || s == 'e' || s == 'i' || s == 'u') {
            return true;
        }
        return false;
    }
    int max(int a, int b) {
        return a > b ? a : b;
    }
    int maxVowels(std::string s, int k) {
        int n = s.length();
        int l = 0;
        int maxvalue = 0;
        int sum = 0;
        for (int r = 0; r < n; r++) {
            if (isVowel(s[r])) {
                sum++;
            }
            if (r - l + 1 > k) {
                if (isVowel(s[l])) {
                    sum--;
                }
                l++;
            }
            maxvalue = max(maxvalue, sum);
        }
        return maxvalue;
    }
};

相关文章
|
24天前
|
存储 搜索推荐 C语言
深入C语言指针,使代码更加灵活(二)
深入C语言指针,使代码更加灵活(二)
|
24天前
|
存储 程序员 编译器
深入C语言指针,使代码更加灵活(一)
深入C语言指针,使代码更加灵活(一)
|
24天前
|
C语言
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
|
3月前
|
存储 大数据 测试技术
掌握 GoLang 中的指针:高效代码的提示和技巧
掌握 GoLang 中的指针:高效代码的提示和技巧
|
5月前
|
Go C++
代码随想录——双指针/滑动窗口(二)
代码随想录——双指针/滑动窗口(二)
|
5月前
代码随想录——双指针(一)
代码随想录——双指针(一)
|
5月前
|
算法
双指针+滑动窗口
双指针+滑动窗口
|
5月前
|
Go C++
代码随想录——双指针/滑动窗口(三)
代码随想录——双指针/滑动窗口(三)
|
26天前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
19 0
|
2月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。