Leetcode之动态规划(DP)专题-486. 预测赢家(Predict the Winner)


给定一个表示分数的非负整数数组。 玩家1从数组任意一端拿取一个分数,随后玩家2继续从剩余数组任意一端拿取分数,然后玩家1拿,……。每次一个玩家只能拿取一个分数,分数被拿取之后不再可取。直到没有剩余分数可取时游戏结束。最终获得分数总和最多的玩家获胜。

给定一个表示分数的数组,预测玩家1是否会成为赢家。你可以假设每个玩家的玩法都会使他的分数最大化。

示例 1:

输入: [1, 5, 2]
输出: False
解释: 一开始,玩家1可以从1和2中进行选择。
如果他选择2(或者1),那么玩家2可以从1(或者2)和5中进行选择。如果玩家2选择了5,那么玩家1则只剩下1(或者2)可选。
所以,玩家1的最终分数为 1 + 2 = 3,而玩家2为 5。
因此,玩家1永远不会成为赢家,返回 False。

示例 2:

输入: [1, 5, 233, 7]
输出: True
解释: 玩家1一开始选择1。然后玩家2必须从5和7中进行选择。无论玩家2选择了哪个,玩家1都可以选择233。
最终,玩家1(234分)比玩家2(12分)获得更多的分数,所以返回 True,表示玩家1可以成为赢家。

注意:

  1. 1 <= 给定的数组长度 <= 20.
  2. 数组里所有分数都为非负数且不会大于10000000。
  3. 如果最终两个玩家的分数相等,那么玩家1仍为赢家。

Leetcode之动态规划(DP)专题-877. 石子游戏(Stone Game)

↑ 本题题解和877题一样,思路也一样。

唯一不同是最后的返回条件的>改为≥

class Solution {
public boolean PredictTheWinner(int[] nums) {
if(nums.length == 0 || nums==null) return false;
if(nums.length == 1) return true;
int[][][] dp = new int[nums.length][nums.length][2]; for (int i = 0; i < nums.length; i++) {
dp[i][i][0] = nums[i];
dp[i][i][1] = 0;
}
for (int k = 2; k <= nums.length; k++) {
for (int i = 0; i <= nums.length - k; i++) {
int j = i+k-1;
int left = nums[i] + dp[i+1][j][1];
int right = nums[j] + dp[i][j-1][1];
if(left>right){
dp[i][j][0] = left;
dp[i][j][1] = dp[i+1][j][0];
}else{
dp[i][j][0] = right;
dp[i][j][1] = dp[i][j-1][0];
}
}
}
return dp[0][nums.length-1][0]>=dp[0][nums.length-1][1];
}
}

最新文章

  1. php查找字符串首次出现的位置 判断字符串是否在另一个字符串中
  2. javascript要不要用来处理业务逻辑
  3. Deep Learning in NLP (一)词向量和语言模型
  4. 服务器如何处理http请求
  5. Android:自定义控件样式(Selector)
  6. POJ1276 - Cash Machine(多重背包)
  7. SQL Server -SET QUOTED_IDENTIFIER
  8. [Python Study Notes] Basic I\O + File 操作
  9. shell脚本中调用另一个脚本的三种不同方法(fork, exec, source)
  10. scrapy顺序执行多个爬虫
  11. Packets larger than max_allowed_packet are not allowed(mysql数据查询提示:不允许超过允许的最大数据包)解决方案
  12. [转]How To Send Transactional Email In A NodeJS App Using The Mailgun API
  13. ffmpeg中AVOption的实现分析
  14. linux驱动编写之阻塞与非阻塞
  15. fetch使用的常见问题及其解决办法
  16. Laravel 的 Homestead 开发环境部署
  17. [转帖]Prometheus+Grafana监控Kubernetes
  18. 23种设计模式之策略模式(Strategy)
  19. log4j2搭建记录
  20. MySQL Block Nested-Loop Join(BNL)

热门文章

  1. cookie和Session是啥?
  2. python镜像
  3. 如何在Google Maps 添加多个标记
  4. Javascritp 数据结构和二叉树算法
  5. 请求返回模板定制,@RestControllerAdvice
  6. js+下载文件夹
  7. 小米oj 判断是否为连乘数字串
  8. golang 文件导入数据追加sheet
  9. Asyncio之EventLoop笔记
  10. 单调队列优化dp(捡垃圾的机器人)