LeetCode每日一题 | 1690. 石子游戏 VII

文章目录

题目描述

原题链接

石子游戏中,爱丽丝和鲍勃轮流进行自己的回合,爱丽丝先开始 。

有 n 块石子排成一排。每个玩家的回合中,可以从行中 移除 最左边的石头或最右边的石头,并获得与该行中剩余石头值之 和 相等的得分。当没有石头可移除时,得分较高者获胜。

鲍勃发现他总是输掉游戏(可怜的鲍勃,他总是输),所以他决定尽力 减小得分的差值 。爱丽丝的目标是最大限度地 扩大得分的差值 。

给你一个整数数组 stones ,其中 stones[i] 表示 从左边开始 的第 i 个石头的值,如果爱丽丝和鲍勃都 发挥出最佳水平 ,请返回他们 得分的差值 。

问题分析

sum[i]为前 i 个石头的值之和

状态定义dp[i][j]表示从第 i 个石头到第 j 个石头,他们得分的差值

状态计算dp[i][j] = max(sum[j + 1] - sum[i + 1] - dp[i + 1][j], sum[j] - sum[i] - dp[i][j - 1])

边界条件dp[i][i] = 0

程序代码

go 复制代码
func stoneGameVII(stones []int) int {
    n := len(stones)
    sum := make([]int, n + 1)
    dp := make([][]int, n)
    for i := 0; i < n; i++ {
        dp[i] = make([]int, n)
    }

    for i := 0; i < n; i++ {
        sum[i + 1] = sum[i] + stones[i]
    }
    
    for s := 2; s <= n; s++ {
        for i := 0; i <= n - s; i++ {
            j := i + s - 1
            dp[i][j] = max(sum[j + 1] - sum[i + 1] - dp[i + 1][j], sum[j] - sum[i] - dp[i][j - 1])
        }
    } 

    return dp[0][n-1]
}
相关推荐
菜鸟233号11 分钟前
力扣669 修剪二叉搜索树 java实现
java·数据结构·算法·leetcode
光羽隹衡25 分钟前
机械学习逻辑回归——银行贷款案例
算法·机器学习·逻辑回归
能源系统预测和优化研究1 小时前
创新点解读:基于非线性二次分解的Ridge-RF-XGBoost时间序列预测(附代码实现)
人工智能·深度学习·算法
执笔论英雄1 小时前
【RL】ROLL下载模型流程
人工智能·算法·机器学习
yaoh.wang1 小时前
力扣(LeetCode) 100: 相同的树 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
SadSunset1 小时前
力扣题目142. 环形链表 II的解法分享,附图解
算法·leetcode·链表
Sunsets_Red2 小时前
2025 FZYZ夏令营游记
java·c语言·c++·python·算法·c#
iAkuya2 小时前
(leetcode)力扣100 19螺旋矩阵(方向数组/边界把控)
算法·leetcode·矩阵
爱编程的小吴2 小时前
【力扣练习题】热题100道【哈希】 最长连续序列
算法·leetcode·职场和发展
qq_336313932 小时前
java基础-方法引用
java·开发语言·算法