1. 石子游戏
    Alice 和 Bob 用几堆石子在做游戏。一共有偶数堆石子,排成一行;每堆都有 正 整数颗石子,数目为 piles[i] 。

游戏以谁手中的石子最多来决出胜负。石子的 总数 是 奇数 ,所以没有平局。

Alice 和 Bob 轮流进行,Alice 先开始 。 每回合,玩家从行的 开始 或 结束 处取走整堆石头。 这种情况一直持续到没有更多的石子堆为止,此时手中 石子最多 的玩家 获胜 。

假设 Alice 和 Bob 都发挥出最佳水平,当 Alice 赢得比赛时返回 true ,当 Bob 赢得比赛时返回 false 。
思路
写这道题的初衷就是,为什么有人的题解写的那么难懂还特么好意思。写不明白就不要写好嘛。
直接思考的话,但凡是先手,都会赢啊。但是总要写一些结构化的代码来证明吧。
直接切到dp,写状态转移方程。(其实还不太懂啥时候用dp。先会用再说吧。一步步来
dp[i][j] 代表 先手 比 后手 大多少
这里有个数组,左端点i 右端点 j
1.拿左边的i的话,就是arr[i] - dp[i + 1][j] 右边就是 j - 1.
取Max
2.状态转移方程有了就要琢磨怎么 让他遍历起来
目标 就是 dp[i][n-1] 是否 大于0.
先找base。总要有base。全未知的话还搞啥
只有一堆石头的时候。不论从左边还是右边 差值都是石子数。先到先得哎
画个图的话。就是对角线有值了。下面部分无意义,忽略。求右上角。
根据状态转移方程,i,j由 左边和下边决定。所以从下向上遍历即可

代码

 public boolean stoneGame(int[] piles) {int n = piles.length;int[][] dp = new int[n][n];for (int i = 0;i < n;i++) {dp[i][i] = piles[i];}for (int i = n - 1;i >=0;i--) {for (int j = i + 1;j < n;j++) {dp[i][j] = Math.max(piles[i] - dp[i + 1][j], piles[j] - dp[i][j-1]);}}return dp[0][n-1] > 0;}

leetcode--石子游戏相关推荐

  1. leetcode——石子游戏系列题目

    石子游戏 亚历克斯和李用几堆石子在做游戏.偶数堆石子排成一行,每堆都有正整数颗石子 piles[i] . 游戏以谁手中的石子最多来决出胜负.石子的总数是奇数,所以没有平局. 亚历克斯和李轮流进行,亚历 ...

  2. LeetCode 1690. 石子游戏 VII(博弈DP)

    文章目录 1. 题目 2. 解题 1. 题目 石子游戏中,爱丽丝和鲍勃轮流进行自己的回合,爱丽丝先开始 . 有 n 块石子排成一排.每个玩家的回合中,可以从行中 移除 最左边的石头或最右边的石头,并获 ...

  3. LeetCode 1686. 石子游戏 VI(贪心)

    文章目录 1. 题目 2. 解题 283 / 1660,前17% 681 / 6572,前10.4% 1. 题目 Alice 和 Bob 轮流玩一个游戏,Alice 先手. 一堆石子里总共有 n 个石 ...

  4. LeetCode 1140. 石子游戏 II(DP)*

    文章目录 1. 题目 2. 解题 1. 题目 亚历克斯和李继续他们的石子游戏.许多堆石子 排成一行,每堆都有正整数颗石子 piles[i].游戏以谁手中的石子最多来决出胜负. 亚历克斯和李轮流进行,亚 ...

  5. LeetCode 1406. 石子游戏 III(DP)

    1. 题目 Alice 和 Bob 用几堆石子在做游戏.几堆石子排成一行,每堆石子都对应一个得分,由数组 stoneValue 给出. Alice 和 Bob 轮流取石子,Alice 总是先开始.在每 ...

  6. LeetCode 1690.石子游戏VII

    LeetCode 1690.石子游戏VII 问题描述: 石子游戏中,爱丽丝和鲍勃轮流进行自己的回合,爱丽丝先开始 . 有 n 块石子排成一排.每个玩家的回合中,可以从行中 移除 最左边的石头或最右边的 ...

  7. LeetCode 1140.石子游戏 II

    题目描述 爱丽丝和鲍勃继续他们的石子游戏.许多堆石子 排成一行,每堆都有正整数颗石子 piles[i].游戏以谁手中的石子最多来决出胜负. 爱丽丝和鲍勃轮流进行,爱丽丝先开始.最初,M = 1. 在每 ...

  8. leetcode算法题--石子游戏 II★★

    原题链接:https://leetcode-cn.com/problems/stone-game-ii/ 相关题目:石子游戏 动态规划: dp[i][j]表示在i~n-1堆石子中,最多拿前2*j堆时先 ...

  9. LeetCode 877. 石子游戏

    1.题目 877. 石子游戏 2.题解 首先,一开始我觉得这道题目并不严谨.因为我大略感觉到先手选择的人就能赢得这个游戏,因为你总是可以在当前的选择中选择对自己有利的拿取方式,而后手只能在剩下的机会中 ...

  10. 2029.石子游戏 IX-LeetCode

    难度:中等 目录 一.问题描述 二.解题思想 三.解题 1.判断极端情况 2.代码实现 一.问题描述 这里我直接采用的LeetCode上面的问题描述. Alice 和 Bob 再次设计了一款新的石子游 ...

最新文章

  1. QT的QMutableHashIterator类的使用
  2. Java基础——Java反射机制及IoC原理
  3. android手动亮度调节,背光闪烁,自动背光调节
  4. java系统参数表有哪些_Java 设置系统参数和运行参数
  5. 图解递归调用过程(Python)
  6. VMware Fusion 启动物理磁盘及U盘的方法
  7. 18种证明公安部门不再开具应该找谁开
  8. 手机最好的html5浏览器,哪款浏览器最好用:六款主流手机浏览器横评
  9. iOS cocoapods的版本升级更新
  10. 微信小程序入门实例--地图
  11. Google 的免费云服务器的 SSH 管理
  12. 【龙印】用龙芯1c实现3D打印机的总体思路
  13. linux命令之partprobe
  14. [轻笔记]多个第三方库typedef重定义冲突
  15. 优秀的产品经理都在读什么?
  16. day15笔记:抽象类和抽象类方法、接口、内部类
  17. error #18 expected a “)”和error #140 too many arguments in function call
  18. 实景三维技术为化工安全生产保驾护航
  19. 将数字格式设置为文本格式,并使其出现左上角绿色小三角
  20. stm32上电不复位,需手动复位问题。

热门文章

  1. 安卓远程控制软件哪个好用
  2. MSP430-流水灯和key
  3. Java 12 Shenandoah GC
  4. ER图向关系模型的转换
  5. 行政区划代码2020(SQL)--(下)
  6. Bibtex 参考文献样式
  7. SQLyog连接MySQL时出现2058错误解决方法
  8. 互联网金融牌照有哪些 金融牌照一览表
  9. 公司电子企业邮箱注册哪个好,电子企业邮箱怎么写?
  10. 双系统window更新后,开机引导错误,grub rescue修复