1423. 可获得的最大点数

本文介绍了如何解决滑动窗口中获取最大点数的问题,通过一个具体的例子阐述了思路。采用滑动窗口的方法,从两端开始考虑,不断更新窗口内的点数和,以找到可能的最大值。代码实现中,利用双指针维护滑动窗口,求解最小窗口和,从而得到最大点数。
摘要由CSDN通过智能技术生成

滑动窗口之可获得的最大点数

几张卡牌 排成一行,每张卡牌都有一个对应的点数。点数由整数数组 cardPoints 给出。
每次行动,你可以从行的开头或者末尾拿一张卡牌,最终你必须正好拿 k 张卡牌。
你的点数就是你拿到手中的所有卡牌的点数之和。
给你一个整数数组 cardPoints 和整数 k,请你返回可以获得的最大点数。

思路

输入:cardPoints = [1,2,3,4,5,6,1], k = 3
输出:12
解释:第一次行动,不管拿哪张牌,你的点数总是 1 。但是,先拿最右边的卡牌将会最大化你的可获得点数。最优策略是拿右边的三张牌,最终点数为 1 + 6 + 5 = 12 。

  • 先看懂题:
    1、要求从第一位或者最后一位出发,即结果要么开头k位,要么结尾k位
    2、要求连续,所以如果正向解决,就是循环整;
  • 使用滑动窗口,就考虑到cardPoints 的长度 - K位,剩下的就是要滑动的窗口的大小,且结果不管是从头开始的K位最大还是从尾巴开始的K 位最大,取中间滑动窗口和最小的就可以。

代码实现

def maxScore(cardPoints: List[int], k: int) -> int:
        res = []
        length = len(cardPoints)
        sum_val = sum(cardPoints)
        i, j = 0, length-k
        temp = sum(cardPoints[i:j])
        while j <= length:
            res.append(temp)
            if i < length:
                temp -= cardPoints[i]
            if j < length:
                temp += cardPoints[j]
            i += 1
            j += 1

        return sum_val-min(res)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值