📣 独立日限时特惠: VIP通行证立减$68
回复: 7
跳转到指定楼层
上一主题 下一主题
收起左侧

Uber 2018 新鲜电面

全局:

2018(10-12月) 码农类General 硕士 全职@uber - 猎头 - 技术电面  | | Other | 在职跳槽

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

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

x
上周领英上SE manager找到我,电话聊了一下,移交recruiter。uber的recruiter很奇怪,早早就要求填身份相关信息,国籍,visa status等。不过还好给了电面,不然还在想是不是暗中过滤掉没身份的。
您好!
本帖隐藏的内容需要积分高于 130 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 130 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies



补充内容 (2018-11-18 02:20):
抱歉有个条件忘记说了,数组已经是sorted的,所以我用2 pointer比较找的重合

补充内容 (2018-11-24 02:23):
居然拿到了昂赛,感人!求大米啊!各位题友们求大米!没米寸步难行啊!谢谢大家!

评分

参与人数 4大米 +11 收起 理由
likers + 3 给你点个赞!
jeromexlee + 2 很有用的信息!
monaziyi + 5 给你点个赞!
lemonb + 1 赞一个

查看全部评分


上一篇:近百道ML和DS面试题分享(不断更新)
下一篇:甲骨文昂塞
🔗
monaziyi 2018-11-18 01:25:06 | 只看该作者
全局:
复杂度 sum(size(array_i)) i from 0 to n, 用map+set 每个数扫一遍
回复

使用道具 举报

🔗
edu 2018-11-23 05:45:52 | 只看该作者
全局:
2 pointers 只能做两个数组,多个数组还需要结合divide-n-conquer, 是吧?
回复

使用道具 举报

🔗
 楼主| ccathyzhu 2018-11-24 02:20:54 | 只看该作者
全局:
edu 发表于 2018-11-23 05:45
2 pointers 只能做两个数组,多个数组还需要结合divide-n-conquer, 是吧?

我是用2 pointer先得到一个答案,用2 pointer做答案和下一个数组,以此循环做完全部数组
回复

使用道具 举报

🔗
jtzgz 2018-11-27 05:43:19 | 只看该作者
全局:
所有数组重合的element。 这一题感觉不难啊。Leet的哪一题?
回复

使用道具 举报

🔗
飞天sb飞翔 2018-11-27 09:25:53 | 只看该作者
全局:
感觉应该有两个方法吧
1. 用一个hashset,把所有数加进去,然后找加不进去的,空间复杂度很高
2.另一个用priorityqueue 然后把第一每个list的第一个element加进去,然后和peek 出来的element 比较,然后如果相等的话,就取出来
回复

使用道具 举报

🔗
johnkonet 2019-1-18 10:15:37 | 只看该作者
全局:
把所有数字加进map的空间复杂读是O(n),n为所有元素的个数。

可以用O(k)空间和O(n)时间完成,k为数组个数(k <= n)。
1. 用一个数组存放k个指针分别指向当前扫描的数组的index。
2.先看第0个数组指向哪个数字(p_0 = 0),然后移动后k-1个数组的指针直到指向相同或更大的数字。如果所有数组都指向相同的数字,那么这个数字所有数组都有。
3.重复步骤2,直到遍历完第一个数组。
注:不用担心为找第0个数组相等的数在后面数组跳过的数,也不用担心后面的数组没遍历完。因为那些数字第0个数组没有,所以必然不是所有数组都包含的数字。

  1. def commonElement(lists):
  2.     if len(lists) == 0:
  3.         return []
  4.     res, indices = [], [0] * len(lists)
  5.     for p, n in enumerate(lists[0]):
  6.         allFound = True
  7.         for lid in range(1, len(lists)):  # iterate over remaining lists
  8.             while indices[lid] < len(lists[lid]) and lists[lid][indices[lid]] < n:
  9.                 indices[lid] += 1
  10.             if indices[lid] == len(lists[lid]) or lists[lid][indices[lid]] > n:
  11.                 allFound = False
  12.                 break  # one list does not contain n
  13.         if allFound:
  14.             res.append(n)  # all lists contain n
  15.     return res
复制代码

评分

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

查看全部评分

回复

使用道具 举报

🔗
tobebeyond 2019-1-24 09:08:56 | 只看该作者
全局:
johnkonet 发表于 2019-1-18 10:15
把所有数字加进map的空间复杂读是O(n),n为所有元素的个数。

可以用O(k)空间和O(n)时间完成,k为数组个 ...

This is awesome!
回复

使用道具 举报

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

本版积分规则

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