[八我司] 介绍一下Uber tech stack和各个大组的情况

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
E轮2.5亿美元融资
K12教育独角兽一起作业
北京-诚聘人工智能/教育/大数据岗
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
码农求职神器Triplebyte:
不用海投
内推多家公司面试
把贵司招聘信息放这里
查看: 2537|回复: 14
收起左侧

Google Japan 店面

[复制链接] |试试Instant~ |关注本帖
YongHaoHu 发表于 2016-7-26 17:04:52 | 显示全部楼层 |阅读模式

2016(4-6月) 码农类General 本科 全职@Google - 内推 -   | Other | fresh grad应届毕业生

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

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

x
国内大三下学生,投了Google Japan 求RP, 感觉是跪了。  
此外,求大神们内推,邮箱christopherwuy at gmail.com  
简介: C > C++ = PHP > Python = R  
Contributor of WineHQ, had sent more than 50 patches about VC++ runtime(msvcr/msvcp).  Some of them are the implementation of tr2::Filesystem Library, tests of tr2::Threads and implementation of complex istream and ostream::operator.

Accepted by Google Summer Of Code 2015, project is implementing Filesystem functions from tr2 namespace on Wine.  
我的简历在LinkedIn:搜索。yonghaohu  

原题:wiggle-sort-ii

一上来就是问题, 一个数组,排序成这样x0 < x1 > x2 < x3 > < > <
然后我就分析,make sure understand the question,
然后说能不能用method like insertion sort, 他说make sense. 牛人云集,一亩三分地
然后我用插入排序的思想跑了一遍, 然后是可以work的. 牛人云集,一亩三分地
然后问我时间复杂度,我最好最坏平均都分析了:

best time: On
worst: On^2
time complexity: O(n^2)
n is the size of array. visit 1point3acres for more.


然后问我有没有办法优化。。我一直尝试用了几个方法,但是都不行,最后他举例子,提示了一下. 围观我们@1point 3 acres

5 < 7 > 5 < 7 > 5 < 7 > 6  
. 牛人云集,一亩三分地

然后排序后 ,提醒我有什么规律,我分析出最后两个数可以交换
然后他问我为什么可以交换成立
于是我重回一些例子,分析了一下,中间有一点跑偏了,我立马问他,what is our question.
然后他说, 是为什么交换可以成立有什么规律。
最后分析出了奇数,偶数下, 可以比较最后两个数,然后交换不
最后我说写pseducode, 他说好。
然后就写, 在写的时候已经比较正式,就是比较了是否为空数组,. 1point 3acres 论坛
而且swap可以不做用其他方法,等等
写完了他就说没有时间了,结束
伪代码是这样的:
. 留学申请论坛-一亩三分地
if(nums.size())
        ….. visit 1point3acres for more.
vector<int> new_array;

new_aray.push_back(nums[0]);. from: 1point3acres
if(size > 1) {. From 1point 3acres bbs
        if(num[1] > num[0])

                push_back(num[1]);

        else
                inserttobegin(num[1]);. more info on 1point3acres

}
       

for(int i=2;i<n; ++i)

{
        if(i%2 == 0) //i&1 {
                if(new_array[i-1] > a[i]) {
                        puish_back(a[i]);

                        swap(a[i-1], a[i]);
/*
int tmp = a[i-1];

a[i-1] = a[i]; 来源一亩.三分地论坛.

a[i] = tmp;. 一亩-三分-地,独家发布

*/ 来源一亩.三分地论坛.

}else {
                push_back(a[i];. 一亩-三分-地,独家发布

.本文原创自1point3acres论坛}
}else {
        if(new_array[i-1] < a[i]) {
                push_bak(a[i];

        swap(a[i..);

}else{
        xx
}
. more info on 1point3acres
}       
}

评分

2

查看全部评分

mkcing 发表于 2016-7-27 06:45:25 | 显示全部楼层
shuyangsheng 发表于 2016-7-27 05:59
worst case 应该是O(nlogn)吧,这不是完整的quick sort。我不是很确定。。。

. 1point3acres其实这题greedy就可以了 ...

这道题用 greedy 是不对的,
如果题目是 a1 >= a2 <= a3 >= a4 <= a5-google 1point3acres
. from: 1point3acres
那么用 greedy 是对的。

比如, 5,5,5, 1,2,3,4,6,7,8,9,  你看看能不能用greedy?
回复 支持 1 反对 0

使用道具 举报

uuisafresh 发表于 2016-7-26 18:26:38 | 显示全部楼层
归并排序 log2n,然后分一半,奇数位放前一半,偶数位放后一半,保证奇数位肯定小于偶数位,这样可否?
回复 支持 反对

使用道具 举报

 楼主| YongHaoHu 发表于 2016-7-26 18:30:19 | 显示全部楼层
uuisafresh 发表于 2016-7-26 18:26
归并排序 log2n,然后分一半,奇数位放前一半,偶数位放后一半,保证奇数位肯定小于偶数位,这样可否?

可以。leetcode上有这么做的,但是他想要比类似插入排序更快方法,which就是他引导出来的办法。 O(n)就可以了。 . From 1point 3acres bbs
ps: 归并排序是 O(n log(n))吧
回复 支持 反对

使用道具 举报

zkern 发表于 2016-7-26 18:30:50 | 显示全部楼层
HR 骗我说必须先做google apac test才能申谷歌。。。 早知道我也直接申了
回复 支持 反对

使用道具 举报

uuisafresh 发表于 2016-7-26 18:43:17 | 显示全部楼层
YongHaoHu 发表于 2016-7-26 18:30-google 1point3acres
可以。leetcode上有这么做的,但是他想要比类似插入排序更快方法,which就是他引导出来的办法。 O(n)就可 ...
. 一亩-三分-地,独家发布
sorry,太久没做题,是nlogn. 牛人云集,一亩三分地

n次,过一遍,找中位数,用中位数把数组分两组,大的放偶位,小的放奇位,这样能否O(n)
回复 支持 反对

使用道具 举报

 楼主| YongHaoHu 发表于 2016-7-26 20:24:19 | 显示全部楼层
zkern 发表于 2016-7-26 18:30
HR 骗我说必须先做google apac test才能申谷歌。。。 早知道我也直接申了

应该我是参加过gsoc,而gsoc当时说,只要成功参加就有内推的
回复 支持 反对

使用道具 举报

mkcing 发表于 2016-7-26 23:41:47 | 显示全部楼层
uuisafresh 发表于 2016-7-26 18:43
sorry,太久没做题,是nlogn

n次,过一遍,找中位数,用中位数把数组分两组,大的放偶位,小的放奇位 ...

正解,但是把大的放在偶数位,小的放在奇数位,而且不用extra space 也需要技巧,https://en.wikipedia.org/wiki/Dutch_national_flag_problem,  需要用到这个技术
Mobile Apps Category (English)728x90
回复 支持 反对

使用道具 举报

jyttwc901231 发表于 2016-7-27 01:57:21 | 显示全部楼层
uuisafresh 发表于 2016-7-26 18:43. 1point3acres
sorry,太久没做题,是nlogn

n次,过一遍,找中位数,用中位数把数组分两组,大的放偶位,小的放奇位 ...

找中位数需要nlogn了吧?
回复 支持 反对

使用道具 举报

mkcing 发表于 2016-7-27 03:32:21 | 显示全部楼层
jyttwc901231 发表于 2016-7-27 01:57
找中位数需要nlogn了吧?
. Waral 博客有更多文章,
O(n)  就可以了,https://en.wikipedia.org/wiki/Quickselect
回复 支持 反对

使用道具 举报

shuyangsheng 发表于 2016-7-27 04:30:03 | 显示全部楼层
mkcing 发表于 2016-7-27 03:32
O(n)  就可以了,https://en.wikipedia.org/wiki/Quickselect
. from: 1point3acres
直接用QuickSelect找中位数最差情况应该不是O(n)吧。每次Select是O(n),但是找到的pivot不一定是中位数,还要视pivot的位置递归左半边或者右半边。
.本文原创自1point3acres论坛
倒是有找到一个O(n)的算法,但是有点follow不上了

http://cs.stackexchange.com/questions/1914/to-find-the-median-of-an-unsorted-array
回复 支持 反对

使用道具 举报

mkcing 发表于 2016-7-27 05:04:08 | 显示全部楼层
shuyangsheng 发表于 2016-7-27 04:30
直接用QuickSelect找中位数最差情况应该不是O(n)吧。每次Select是O(n),但是找到的pivot不一定是中位数, ...

average 是 O(n)  worst case是 O(n^2)
回复 支持 反对

使用道具 举报

DailyGrind 发表于 2016-7-27 05:17:27 | 显示全部楼层
同乡顶一下!
回复 支持 反对

使用道具 举报

shuyangsheng 发表于 2016-7-27 05:59:46 | 显示全部楼层
mkcing 发表于 2016-7-27 05:04. 围观我们@1point 3 acres
average 是 O(n)  worst case是 O(n^2)

worst case 应该是O(nlogn)吧,这不是完整的quick sort。我不是很确定。。。

其实这题greedy就可以了:
  1.     def wiggleSort(self, nums):-google 1point3acres
  2.         # Write your code here
  3.         for i in range(1,len(nums)):
  4.             if (i%2==0 and nums[i] > nums[i-1]) or (i%2==1 and nums[i] < nums[i-1]):
  5.                 nums[i],nums[i-1] = nums[i-1],nums[i]
复制代码
举个例子 a=[3,1,4],那么要求就是[a0 a1] 上升,[a1,a2] 下降。
第一步 [a0 a1] 交换,得到[1,3,4],这时候[a0 a1] 满足了上升条件。
第二步 [a1 a2]=[3,4] 要求下降,所以要交换成[1,4,3]。
我们知道 3 是大于 1 的,而 4 > 3,  所以 4 必然大于 3,所以 4 > 1 必然成立,也就是说后面的交换并不影响前面已经wiggle排好的序列。

找中位数的做法我写了半天也不太对,可能智商有限,数列长度是奇数的时候中间那个元素怎么处理有点捉急。。。
回复 支持 反对

使用道具 举报

jooppp 发表于 2016-8-14 16:30:33 | 显示全部楼层
hello , I am sorry that i cannot type Chinese now.
Did you answer only this question? did the recruiter ask any other questions?
Also , is this  interview for intern or full-time?
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2018-5-25 09:41

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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