leetcode 1423. 可获得的最大点数(滑动窗口)
生活随笔
收集整理的這篇文章主要介紹了
leetcode 1423. 可获得的最大点数(滑动窗口)
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
幾張卡牌 排成一行,每張卡牌都有一個對應(yīng)的點數(shù)。點數(shù)由整數(shù)數(shù)組 cardPoints 給出。
每次行動,你可以從行的開頭或者末尾拿一張卡牌,最終你必須正好拿 k 張卡牌。
你的點數(shù)就是你拿到手中的所有卡牌的點數(shù)之和。
給你一個整數(shù)數(shù)組 cardPoints 和整數(shù) k,請你返回可以獲得的最大點數(shù)。
示例 1:
輸入:cardPoints = [1,2,3,4,5,6,1], k = 3
輸出:12
解釋:第一次行動,不管拿哪張牌,你的點數(shù)總是 1 。但是,先拿最右邊的卡牌將會最大化你的可獲得點數(shù)。最優(yōu)策略是拿右邊的三張牌,最終點數(shù)為 1 + 6 + 5 = 12 。
代碼
class Solution {public int maxScore(int[] cardPoints, int k) {//將題目轉(zhuǎn)化為求累加和最小的滑動窗口int l=0,r=0,n=cardPoints.length,tar=n-k,cur=0;for(;r<tar;r++)//初始化第一個滑動窗口cur+=cardPoints[r];int res=cur;while (r<n){cur-=cardPoints[l++];cur+=cardPoints[r++]; res= Math.min(res,cur);}int sum=Arrays.stream(cardPoints).sum();return sum-res;} }總結(jié)
以上是生活随笔為你收集整理的leetcode 1423. 可获得的最大点数(滑动窗口)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 做梦梦到夫妻两个人打架什么意思
- 下一篇: spring— Spring与Web环境