一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 1312|回复: 1
收起左侧

Zenefits phone

[复制链接] |试试Instant~ |关注本帖
johnnywsd 发表于 2015-5-11 16:06:54 | 显示全部楼层 |阅读模式

2015(4-6月) 码农类 硕士 全职@Zenefits - 网上海投 - 技术电面 |Other在职跳槽

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

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

x
Given array of whole numbers and a starting index, find out if you can win
Winning means ending up at an array value of 0
If you are at a position that has a value that is not a 0, you can move value times to the left or to the right 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
[1, 3, 0, 2, 2], i == 0 -> true. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
[1, 1], i == 1 -> false


评分

1

查看全部评分

本帖被以下淘专辑推荐:

 楼主| johnnywsd 发表于 2015-5-11 16:07:26 | 显示全部楼层
  1. class Foo():

  2.     def __init__(self):
  3.         self._array = None
  4.         self._array_length = 0

  5.     def isWin(self, array, i):
  6.         self._array = array
  7.         self._array_length = len(array)
  8.         return self._dfs(i)

  9.     def _dfs(self, idx):
  10.         if idx is None or not 0<= idx < self._array_length:
  11.             return False

  12.         step = self._array[idx]

  13.         if step is None:. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  14.             return False
  15.         if step == 0:
  16.             return True

  17.         tmp, self._array[idx] = self._array[idx], None. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  18.         left_idx = idx - step
  19.         right_idx = idx + step
  20.         left = left_idx if 0<= left_idx < self._array_length else None. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  21.         right = right_idx if 0<= right_idx < self._array_length else None
  22.         res = self._dfs(left) or self._dfs(right)
  23.         self._array[idx] = tmp. From 1point 3acres bbs
  24.         return res
复制代码

评分

1

查看全部评分

回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-10 09:36

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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