回复: 9
跳转到指定楼层
上一主题 下一主题
收起左侧

Google面经题 guess game cost

全局:

2016(1-3月) 码农类General 硕士 全职@google - 内推 - HR筛选  | | Other | 其他

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

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
google 一道面经题
第二道题目是guess number game with cost,
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies

有大神遇到过吗?这个题具体是什么呢?


上一篇:Factual电面求面经
下一篇:跪求Neulion面经
推荐
ctzsm 2016-3-28 02:59:39 | 只看该作者
全局:
  1. f[i][i] = 0 for 1 <= i <= 100,
  2. f[i][j] = min{max(f[i][k - 1], f[k + 1][j]) + k} for i < k < j,
复制代码

评分

参与人数 2大米 +6 收起 理由
陈润鹏 + 1 回答的很好!
bobzhang2004 + 5 回答的很好!

查看全部评分

回复

使用道具 举报

🔗
user123456 2016-3-28 01:59:58 | 只看该作者
全局:
Guessing game - I pick a number between 1 and 100 and you   are trying to guess it. Every time you query a number I tell you if it is higher or lower. Part 1- Write the code of it, if cost of querying a number is equal. Part 2- How about if cost of querying number x is x? How would you change the algorithm?

评分

参与人数 1大米 +3 收起 理由
bobzhang2004 + 3 回答的很好!

查看全部评分

回复

使用道具 举报

🔗
 楼主| bobzhang2004 2016-3-28 02:13:07 | 只看该作者
全局:
[quote][url=forum.php?mod=redirect

大神可以说下解法吗?
回复

使用道具 举报

🔗
adiggo 2016-3-28 02:48:26 | 只看该作者
全局:
user123456 发表于 2016-3-28 01:59
Guessing game - I pick a number between 1 and 100 and you   are trying to guess it. Every time you q ...

第二题 加入了cost, 那么是希望改binary search, 让cost减小么。请问思路是什么
回复

使用道具 举报

🔗
ctzsm 2016-3-28 02:49:36 | 只看该作者
全局:
f[i][i] = 0 for 1 <= i <= 100,
f[i][j] = min(max(f[i][k - 1], f[k + 1][j]) + k) for i < k < j,
另外再开一个数组g记录下最优决策时候的k,然后二分的时候替换m = (l + r) / 2为m = g[l][r]

补充内容 (2016-3-28 02:54):
这就是算导上最优二叉搜索树的应用。

补充内容 (2016-3-28 02:57):
补充了之后
f[i][i] = 0 for 1 <= i <= 100,
f[i][j] = min(max(f[i][k - 1], f[k + 1][j]) + k) for i < k < j
被吞了。。
回复

使用道具 举报

🔗
 楼主| bobzhang2004 2016-3-28 23:37:30 | 只看该作者
全局:

写了下Java code,不确定是不是对了
  1. public class GuessNumberGameWithCost {

  2.         public static void main(String[] args) {
  3.                 int res = guessGameFollowUp();
  4.                 System.out.println(res);
  5.         }

  6.        
  7.         public static int guessGameFollowUp() {
  8.                 int[][] f = new int[100 + 1][100 + 1];
  9.                 for (int i = 1; i <= 100; i++) {
  10.                         f[i][i] = i;
  11.                 }
  12.                 for (int len = 2; len <= 100; len++) {
  13.                         for (int i = 1; i <= 100 - len + 1; i++) {
  14.                                 int j = i + len - 1;
  15.                                
  16.                                 if (len == 2) {
  17.                                         f[i][j] = Math.max(f[i][i], f[j][j]);
  18.                                 } else {
  19.                                         f[i][j] = Integer.MAX_VALUE;
  20.                                         for (int k = i + 1; k < j; k++) {
  21.                                                 f[i][j] = Math.min(f[i][j], Math.max(f[i][k - 1], f[k + 1][j]) + k);
  22.                                         }
  23.                                 }
  24.                         }
  25.                 }

  26.                 return f[1][100];
  27.         }
  28. }
复制代码
回复

使用道具 举报

🔗
qiuxuxing007 2016-4-5 14:10:23 | 只看该作者
全局:
这段程序答案出来的有问题, 我在eclipse上跑了一下死452
回复

使用道具 举报

🔗
wsrrzxl 2016-4-7 06:25:14 | 只看该作者
全局:
bobzhang2004 发表于 2016-3-28 23:37
写了下Java code,不确定是不是对了

楼主请问dp的状态代表什么?
回复

使用道具 举报

🔗
adiggo 2016-4-9 04:10:20 | 只看该作者
全局:
wsrrzxl 发表于 2016-4-7 06:25
楼主请问dp的状态代表什么?

dp[i][i] 应该是最小的cost 在range(i, i)之间inclusive。 所以dp[i][i] = 0 因为不需要 guess。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

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