【算法思考记录】力扣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;
    }
}

相关推荐
悄悄地努力8 分钟前
IDEA 新建 SpringBoot 项目时,没有高版本 SpringBoot 可选
java·spring boot·intellij-idea
じ☆ve 清风°13 分钟前
滑动窗口算法详解与C++实现
开发语言·c++·算法
东莞呵呵37 分钟前
吴恩达机器学习(1)——机器学习算法分类
算法·机器学习·分类
救救孩子把1 小时前
Mac 环境下 JDK 版本切换全指南
java·开发语言·macos
路飞雪吖~1 小时前
【Linux】共享内存
java·linux·服务器
caihuayuan41 小时前
鸿蒙AI开发:10-多模态大模型与原子化服务的集成
java·大数据·sql·spring·课程设计
张哈大1 小时前
【 Redis | 实战篇 秒杀优化 】
java·数据库·redis·笔记·缓存
低维歌者2 小时前
python训练营day27
java·开发语言·python
大帅不是我2 小时前
Python多进程编程执行任务
java·前端·python
purrrew3 小时前
【Java ee初阶】jvm(3)
java·jvm