【算法思考记录】力扣1423. 可获得的最大点数[Java, 滑动窗口]


Problem: 1423. 可获得的最大点数

date: "2023-12-03"


问题重述

正难则反,发挥逆向思维,因为最终无法选择的点数是一个连续区间,所以问题可转换成:在一个给定的数组中,我们需要找到移除长度为 n-k 的子数组后,剩余元素的最大总和。这是一个典型的算法问题,其中数据量达到 10^5,要求找到一种高效的解法。

解决思路

初步考虑使用深度优先搜索(DFS)或动态规划,但由于状态定义复杂且效率不高,因此我们转而使用滑动窗口的方法。这种方法不仅简化了问题,还大幅提高了算法的效率。

滑动窗口策略

核心思路是维护一个固定长度为 n-k 的窗口,通过不断移动这个窗口来找出使剩余部分总和最大的子数组。具体步骤如下:

  1. 计算数组的总和。
  2. 初始化窗口大小为 n-k
  3. 使用两个指针 leftright 来标记窗口的左右边界。
  4. 移动 right 指针扩展窗口,直到达到窗口大小。
  5. 更新最大得分,并逐步移动 left 指针来缩小窗口,同时移动 right 指针继续扫描。
  6. 在每次移动窗口时,更新并记录最大得分。

窗口大小为0时的特殊情况处理

此时无需维护任何滑动窗口,因为total就是答案本身,直接返回即可。

Java代码实现

python 复制代码
class Solution {
    public int maxScore(int[] cardPoints, int k) {
        int n = cardPoints.length;
        int winSize = n - k;
        int total = 0;
        for (int cardPoint : cardPoints) {
            total += cardPoint;
        }
        if (winSize == 0) {
            return total;
        }

        int winSum = 0, ans = 0, left = 0, right = 0;
        while (right < n) {
            winSum += cardPoints[right];
            if (right - left + 1 == winSize) {
                ans = Math.max(ans, total - winSum);
                winSum -= cardPoints[left];
                left++;
            }
            right++;
        }
        return ans;
    }
}

相关推荐
皮影w9 分钟前
Java SpringAOP入门
java·开发语言
007php00712 分钟前
Redis面试题解析:Redis的数据过期策略
java·网络·redis·缓存·面试·职场和发展·php
小青龙emmm22 分钟前
2025级C语言第四次周测题解
c语言·开发语言·算法
树在风中摇曳32 分钟前
【牛客排序题详解】归并排序 & 快速排序深度解析(含 C 语言完整实现)
c语言·开发语言·算法
minji...36 分钟前
算法---模拟/高精度/枚举
数据结构·c++·算法·高精度·模拟·枚举
w***488236 分钟前
Spring Boot3.x集成Flowable7.x(一)Spring Boot集成与设计、部署、发起、完成简单流程
java·spring boot·后端
u***1371 小时前
详解tomcat中的jmx监控
java·tomcat
Vic101011 小时前
Java 序列化与反序列化:深入解析与实践
java·开发语言
后端小张1 小时前
【JAVA 进阶】Spring Cloud 微服务全栈实践:从认知到落地
java·开发语言·spring boot·spring·spring cloud·微服务·原理
zl9798991 小时前
RabbitMQ-发布确认高级
java·分布式·rabbitmq