查看: 1333|回复: 12
收起左侧

roblox 店面 karat

|只看干货
本楼: 👍   100% (1)
 
 
0% (0)   👎
全局: 👍   100% (7)
 
 
0% (0)    👎

2022(4-6月) 码农类General 本科 全职@Roblox - 内推 - 技术电面  | 😐 Neutral 😐 AverageOther | 在职跳槽

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

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

x
As you are reading the book multiple times, you notice that you always get bad endings. You start to suspect there is no way to get to the good endings, so you decide to find out.

Good and bad endings will be separate lists of page numbers, like this:

good_endings = [10, 15, 25, 34]
bad_endings = [21, 30, 40]

Given lists of good endings, bad endings, and a list of the choices along with their options, return a collection of all the reachable good endings, if any.

Examples:

choices1 = [[3, 16, 24]]
find_good_endings(good_endings, bad_endings, choices1)
  Start: 1 -> 2 -> 3(choice) -> 16 -> 17... -> 21(bad ending)
                   |
                   -> 24 -> 25(good ending)
Thus it is possible to reach the good ending at 25 but no others, so we return [25].

choices2 = [[3, 16, 20]]
find_good_endings(good_endings, bad_endings, choices2)
  Start: 1 -> 2 -> 3(choice) -> 16 -> 17... -> 21(bad ending)
                   |
                   > 20 -> 21(bad ending)
No good ending is reachable, so return [].

Additional Inputs:
choices3 = [[3, 2, 19], [20, 21, 34]]
choices4 = []
choices5 = [[9, 16, 26], [14, 16, 13], [27, 29, 28], [28, 15, 34], [29, 30, 38]]
choices6 = [[9, 16, 26], [13, 31, 14], [14, 16, 13], [27, 12, 24], [32, 34, 15]]
choices7 = [[3, 9, 10]]

Complexity Variable:
n = number of pages
(endings
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
ndings, badEndings, choices2) => []
findGoodEndings(goodEndings, badEndings, choices3) => [34]
findGoodEndings(goodEndings, badEndings, choices4) => [10]
findGoodEndings(goodEndings, badEndings, choices5) => [15, 34]
findGoodEndings(goodEndings, badEndings, choices6) => [15, 25, 34]
findGoodEndings(goodEndings, badEndings, choices7) => [10]

评分

参与人数 3大米 +10 收起 理由
清道神君 + 8
731aladdin + 1 给你点个赞!
aaronz20 + 1 赞一个

查看全部评分


上一篇:🐶狗面经
下一篇:Oracle 挂经
本楼: 👍   100% (2)
 
 
0% (0)   👎
全局: 👍   100% (302)
 
 
0% (0)    👎
本帖最后由 superzbh 于 2022-7-22 16:10 编辑

这应该是一道graph 题 做了一下 test case 都能 pass  希望对大家有帮助
  1. from collections import defaultdict, deque

  2. def find_good_endings(goodEnding, badEnding, choices):
  3.    
  4.     # neighborMap --> {"fromPage": [toPage1, toPage2]}
  5.     neighborMap = defaultdict(list)
  6.    
  7.     for choice in choices:
  8.         fromPage = choice[0]
  9.         
  10.         for toPage in choice[1:]:
  11.             neighborMap[fromPage].append(toPage)
  12.    
  13.     # find max end page
  14.     maxEndPage = float("-inf")
  15.     for goodEnd in goodEnding:
  16.         maxEndPage = max(goodEnd, maxEndPage)
  17.    
  18.     for badEnd in badEnding:
  19.         maxEndPage = max(badEnd, maxEndPage)
  20.    
  21.     for i in range(maxEndPage):
  22.         if i in neighborMap:
  23.             continue
  24.         
  25.         neighborMap[i].append(i+1)
  26.    
  27.     que = deque()
  28.     que.append((1))
  29.    
  30.     goodEndingSet = set(goodEnding)
  31.     badEndingSet = set(badEnding)
  32.     result = set()
  33.    
  34.     visited = set()
  35.     visited.add(1)
  36.    
  37.     while que:
  38.         curNode = que.popleft()
  39.         
  40.         if curNode in goodEndingSet:
  41.             result.add(curNode)
  42.             continue
  43.         
  44.         elif curNode in badEndingSet:
  45.             continue
  46.         
  47.         for neighbor in neighborMap[curNode]:
  48.             if neighbor not in visited:
  49.                 que.append(neighbor)
  50.                 visited.add(neighbor)
  51.    
  52.     return sorted(list(result)) if result else []
复制代码
回复

使用道具 举报

地里的匿名用户
匿名用户-450  2022-7-5 04:43:17
本楼: 👍   100% (1)
 
 
0% (0)   👎
这题有点confusing啊。choice4是空的为什么会有good ending == [10]呢。如果这是因为这题的assumption是读者永远从page1开始读,那为什么choice3的good ending不包含10呢?choice3的第二个元素[20, 21, 34]的第一个元素是20,如果读者从page1开始读那应该会先遇到good ending 10
扫码关注一亩三分地求职与职场公众号
更多干货内容等你发现
回复

使用道具 举报

本楼: 👍   100% (1)
 
 
0% (0)   👎
全局: 👍   93% (1902)
 
 
6% (123)    👎
看起来是三个 heap,扫一次 O(N) 解决?
回复

使用道具 举报

地里的匿名用户
匿名用户-108  2022-7-6 13:40:33
本楼: 👍   0% (0)
 
 
0% (0)   👎
"a list of the choices along with their options" 这个是啥子意思哟,栗子也看不懂啊,为啥是二维数组,LZ 解释一下呗
回复

使用道具 举报

 楼主| 755e995 2022-7-7 11:32:30 | 显示全部楼层 | 🔍试试Job多多
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (7)
 
 
0% (0)    👎
choices 第一个就是 page number 你碰到 这个page 你有两个选择 就是 choices[1] 或者chocies[2] 然后你的page 直接跳转到1 或者 2

评分

参与人数 1大米 +1 收起 理由
james8613503 + 1 很有用的信息!

查看全部评分

回复

使用道具 举报

地里的匿名用户
匿名用户-324  2022-7-7 13:18:54
本楼: 👍   0% (0)
 
 
0% (0)   👎
您好能不能问一下您电面之后多久出的结果呢?
回复

使用道具 举报

本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   99% (121)
 
 
0% (1)    👎
这一题没思路啊。。楼主最后怎么求解的呢?求高人指点
回复

使用道具 举报

本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   99% (121)
 
 
0% (1)    👎
匿名用户 发表于 2022-7-4 13:43
这题有点confusing啊。choice4是空的为什么会有good ending == [10]呢。如果这是因为这题的assumption是读 ...

因为choice3中走到3会跳到19, 然后19中走到20之后又会跳到34。不知道理解的对不对
回复

使用道具 举报

本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   97% (2408)
 
 
2% (68)    👎
我没明白,这里的All Test Cases - snake_case: 和All Test Cases - camelCase: 不都是一模一样的测试案例么,为啥要写两次?
回复

使用道具 举报

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

本版积分规则

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