AcWing刷题-游戏

游戏


DP

python 复制代码
l = lambda: [int(x) for x in input().split()]

n = l()[0]
w = [0]
while len(w) <= n:
	w += l()

s = [0] * (n + 1)
for i in range(1, n + 1): 
    s[i] = s[i - 1] + w[i]

f = [[0] * (n + 1) for _ in range(n + 1)]

for i in range(1, n + 1): 
    f[i][i] = w[i]

for length in range(2, n + 1):
  for i in range(1, n - length + 2):
    j = i + length - 1
    # 取最优解
    f[i][j] = max(
      s[j] - s[i - 1] - f[i + 1][j],
      s[j] - s[i - 1] - f[i][j - 1]
    )

print(f[1][n], s[n] - f[1][n])
相关推荐
用户12039112947264 分钟前
打破信息壁垒:手把手教你实现DeepSeek大模型的天气查询功能
python·openai
普通网友17 分钟前
模板编译期机器学习
开发语言·c++·算法
普通网友19 分钟前
C++与机器学习框架
开发语言·c++·算法
普通网友19 分钟前
C++安全编程指南
开发语言·c++·算法
鱼骨不是鱼翅29 分钟前
力扣hot100----1day
python·算法·leetcode·职场和发展
2501_9412362130 分钟前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
程序猿_极客32 分钟前
【2025 最新】 Python 安装教程 以及 Pycharm 安装教程(超详细图文指南,附常见问题解决)
开发语言·python·pycharm·python安装以及配置
2501_9412357333 分钟前
C++中的装饰器模式变体
开发语言·c++·算法
2501_9411112533 分钟前
基于C++的爬虫框架
开发语言·c++·算法
小欣加油35 分钟前
leetcode 429 N叉树的层序遍历
数据结构·c++·算法·leetcode·职场和发展