【leetcode 486】 动态规划&两端取数

leetcode486动态规划&playerAB从数组两端挑数字,求最大player

1、题目大意

给一个整型数组nums,两个人依次从数组中的头或者尾拿一个数,判断是否player1拿到的总数大于或者等于player2~如果是就返回true,否则返回false~

2、分析

这道题的关键思路在于:

1、我们不需要去考虑玩家A拿到的数字总和究竟是多少,只要他大于玩家二即可。

2、这个问题应该是一个递归问题,我们如何定义动态数组去记录玩家A的状态,并且可以通过递归,根据上一状态的结果得到当前状态的结果。

所以,我们考虑

1、构建动态数组DP[n][n]

其中,n表示原数组长度,DP[i][j]代表的是,从nums[i]到nums[j],A玩家的总分减去B玩家总分,所得到的值

2、递归表达书:

DP[i][i] =nums[i]

DP[i][j] = max(nums[i]-DP[i+1][j], nums[j]-DP[i][j-1])

3、循环的设置

外层循环:因为当i-j=0时,其DP值已知,所以我们设置外层循环为ij链的长度k,从1到n-1

内层循环:对于长度为k的ij链,其初始点为: range(nums[0], nums[n-k])

3、代码


                
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值