记一段很虐心的亚麻秋季实习经历 + 转CS 拿到Dream Company Offer的神奇经历

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货

最近看过此主题的会员

E轮2.5亿美元融资
K12教育独角兽一起作业诚聘
机器学习/数据统计/教育等职位
码农求职神器Triplebyte:
不用海投
内推多家公司面试
高效直聘+内推,70%面试率
AI帮你免费完善简历
直击全美十万个科技职位
坐标湾区
DreamCraft创始团队
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
锦晖律师事务所
12月16日
H1B讲座通知
查看: 1131|回复: 4
收起左侧

[动态规划] 问一道题 coins in line II

[复制链接] |试试Instant~
我的人缘0
33847682 发表于 2016-10-11 12:15:01 | 显示全部楼层 |阅读模式
本楼: 【顶】   0% (0)
 
 
0% (0)   【踩】
全局: 顶  70% (86)
 
 
29% (36)  踩

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?Sign Up 注册获取更多干货

x
dp[i] = values[i] + Math.min(dp[i+2],dp[i+3]);
dp[i] = Math.max(dp[i],values[i]+values[i+1]+ Math.min(dp[i+3],dp[i+4]));
状态转移方程大概是这样 我想问这里为什么要最小化选手1可以取得硬币的值 题目只是问选手1是赢还是输没有必要取最坏情况吧?
这里取max不行吗?让对手都选最少的 取最好的情况 看能不能赢

上一篇:一起刷题! [Python]
下一篇:leetcode原来session记录没有了,求助
我的人缘0
stellari 发表于 2016-10-12 08:15:42 | 显示全部楼层
本楼: 【顶】   0% (0)
 
 
0% (0)   【踩】
全局: 顶  98% (408)
 
 
1% (5)  踩
题目虽然没有明说, 但是问你"will XXX win"的题, 一般都暗含"双方都采取最优策略"这个假设, 否则这题就没什么意思了. 所以, 之所以状态转移方程要"最小化选手1可以在i以后取得硬币的值", 是因为选手2为了获胜一定会这么做, 因此状态转移方程必须模拟对手的这个策略.
回复

使用道具 举报

全球28万学生4.7分推荐
我的人缘0
 楼主| 33847682 发表于 2016-10-12 09:46:31 | 显示全部楼层
本楼: 【顶】   0% (0)
 
 
0% (0)   【踩】
全局: 顶  70% (86)
 
 
29% (36)  踩
stellari 发表于 2016-10-12 08:15
题目虽然没有明说, 但是问你"will XXX win"的题, 一般都暗含"双方都采取最优策略"这个假设, 否则这题就没什 ...

多谢大神 所以这种博弈论的题目都是要考虑自己可以选择的最差选择里面取最优?
回复

使用道具 举报

我的人缘0
stellari 发表于 2016-10-12 12:47:47 | 显示全部楼层
本楼: 【顶】   0% (0)
 
 
0% (0)   【踩】
全局: 顶  98% (408)
 
 
1% (5)  踩
33847682 发表于 2016-10-12 09:46
多谢大神 所以这种博弈论的题目都是要考虑自己可以选择的最差选择里面取最优?

这是一种可行的思路. 另外你也可以这样考虑: 令dp[ i ]为"到游戏结束为止, 在i处先拿的人比后拿的人能够多拿的面值".  如果i处先拿的人只拿1枚, 那么在i处他比对方多拿values[ i ], 但是在i+1~N处,对手可以比他多拿dp[ i+1 ], 也就是他比对手多拿-dp[ i + 1]. 因此从i到N, 他比对方多拿values[ i ]-dp[ i+1 ];同理, 如果先拿的人拿2枚, 那么能比对方多拿values[ i ] + values [ i + 1] - dp[ i + 2] .取这二者最大值即可得 dp [ i ], 最后看dp [ 0 ] 是大于还是小于 0 即可. 这样的话, 状态转移方程会比你说的那个解法要简单些, 而且也没有"最差选择"这种思维方式.
回复

使用道具 举报

我的人缘0
 楼主| 33847682 发表于 2016-10-12 13:12:57 | 显示全部楼层
本楼: 【顶】   0% (0)
 
 
0% (0)   【踩】
全局: 顶  70% (86)
 
 
29% (36)  踩
stellari 发表于 2016-10-12 12:47
这是一种可行的思路. 另外你也可以这样考虑: 令dp[ i ]为"到游戏结束为止, 在i处先拿的人比后拿的人能够 ...

明白了 那像这种minmax的题目都可以像你说的这种方法去考虑嘛? 比如Guess Number Higher or Lower II这道题 用minmax是可以做出来的 用你的想法可以做嘛?
回复

使用道具 举报

游客
请先登录

本版积分规则

提醒:发帖可以选择内容隐藏,部分板块支持匿名发帖。请认真读完以下全部说明:

■隐藏内容方法 - 不要多加空格: [hide=200]你想要隐藏的内容比如面经[/hide]
■意思是:用户积分低于200则看不到被隐藏的内容
■可以自行设置积分值,不建议太高(200以上太多人看不到),也不建议太低(那就没必要隐藏了)
■建议只隐藏关键内容,比如具体的面试题目、涉及隐私的信息,大部分内容没必要隐藏。
■微信/QQ/电子邮件等,为防止将来被骚扰甚至人肉,以论坛私信方式发给对方最安全。
■匿名发帖的板块和方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

手机版|小黑屋|一亩三分地留学网

GMT+8, 2018-12-14 17:47

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表