Golang | Leetcode Golang题解之第486题预测赢家

题目:

题解:

Go 复制代码
func PredictTheWinner(nums []int) bool {
    return total(nums, 0, len(nums) - 1, 1) >= 0
}

func total(nums []int, start, end int, turn int) int {
    if start == end {
        return nums[start] * turn
    }
    scoreStart := nums[start] * turn + total(nums, start + 1, end, -turn)
    scoreEnd := nums[end] * turn + total(nums, start, end - 1, -turn)
    return max(scoreStart * turn, scoreEnd * turn) * turn
}

func max(x, y int) int {
    if x > y {
        return x
    }
    return y
}
相关推荐
王码码20354 小时前
Go语言的测试:从单元测试到集成测试
后端·golang·go·接口
王码码20355 小时前
Go语言中的测试:从单元测试到集成测试
后端·golang·go·接口
鹿角片ljp5 小时前
最长回文子串(LeetCode 5)详解
算法·leetcode·职场和发展
lolo大魔王6 小时前
Go语言的异常处理
开发语言·后端·golang
故事和你9111 小时前
洛谷-算法1-7-搜索2
数据结构·c++·算法·leetcode·深度优先·动态规划·图论
YuanDaima204812 小时前
双指针基础原理与题目说明
数据结构·人工智能·python·算法·leetcode·手撕代码
止语Lab13 小时前
Go 内存管理优化:内联是逃逸分析的隐藏杠杆
golang
绿豆人13 小时前
Go设计模式学习
学习·设计模式·golang
.柒宇.14 小时前
力扣hot100之最大子数组和(Java版)
数据结构·算法·leetcode
6Hzlia14 小时前
【Hot 100 刷题计划】 LeetCode 131. 分割回文串 | C++ 回溯算法基础切割法
c++·算法·leetcode