一秒天堂,下一秒地狱经历7轮Google面试,不知道自己怎么挺过来的(1)

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

简历投递

之前校招其实也参加过,无奈门槛太高,竞争压力太大,连面试流程都木有进。当初校招时直接网上刷题,这个网站上其实还能看到往年的一些题目情况: Google Code Jam。基本上分几轮,每轮 top xx 的选手才有机会进入面试。

第一次换工作的时候,其实也有找在 Google 的同学内推,填了不少内推推荐理由呀等等,最后简历都没过。

当然,简历没过肯定也有多种理由啦,这个其实跟各个公司都一样。比如人家需求是招聘 P7,以你的工作年限经验等最多就 P6,肯定不行; 还有比如希望是招聘机器学习等相关经验的等等,岗位信息等不匹配也不行; 当然还有一种,岗位描述等都相关,确实简历没啥亮点,太平庸,也直接被 HR 给筛选掉了。

这次其实刚开始是没有考虑过面 Google 的,机缘巧合在 linkedin 在有 Google 的 HR 联系,说要不要试试 Google 的机会。当然就抱着 “试试就试试” 的想法跟进面试流程啦。既然要尝试,当然还是需要认真对待,修改简历。

防止手生,肯定需要提前准备”刷题”的。发简历给HR 小姐姐后,HR 小姐姐会给你一些准备材料供你参考,这份材料还相对比较丰富,直接会告诉你面试涉及到的知识点,推荐书籍还有一些推荐参考的视频等。需要的小伙伴可以留言,我整理下发给你(跟 HR 求证过,这些资料是可以公开分享的哈)。

其实,时间有限,“刷题”准备不够,当初预感估计面试面不下来。不过真正走完所有面试流程,发现其实面试题目没有想象中的那么难(然而,我仍然没有过,说明实力不足呀),积极准备,还是有希望的。因为面试题目比较敏感,不能直接分享原题哈,不过我会根据我的理解,找类似知识点和类似难度的题目分享一下。

HR 面试

对,第一轮就是 HR 面试,上面流程中的 “Recruiter Prescreen”,其实就是一些计算机相关基础的填空题和选择题。几分钟的时间,十几道题目。面试过程中,不需要给予明确的解释,知道就是知道,不知道就不知道。题目可能会涉及到比如: 快排的时间复杂度是多少? 选择排序是稳定的排序算法吗? 等等之类的。

这也是我参与的所有面试当中,HR 直接参与的”技术”面试。我理解就通过这一轮面试可以用比较少的成本把一些不合适的候选人直接排除了。当然这种方法可能不一定适用于所有公司。

电话面试

电话面试要求直接用 Google doc 共享写代码,需要要求你有一个稳定的网络环境。这轮面试我理解应该不会太难,从我面试的经验来看也确实如此。

相比 onsite,电话面试不能在一个很好的沟通环境下,不能面对面和面试官进行交流。当初我面试的一道题目和二叉树的遍历相关,当然题目不会是直接写二叉树的先序/中序/后序/层次之类的遍历,会有一个具体的业务场景在里边。

需要你分析这个具体的业务场景,能够抽象出题目本质上就是 二叉树的遍历方法。这道题目算是拿下了。实际 coding 后,面试官可能会根据你写的 code 去提问,一些边界条件以及让你提优化方案。

HR 小姐姐介绍的电话面试是 1-2 轮,其实我理解,这应该是需要看第一轮的面试官的反馈,是否犹豫是否再安排一轮电话面试。毕竟和 onsite 相比,电话面试成本相对更低一些。

在线 code 其实在面试过程中,还是蛮重要的环节。从你 code 的细节,包括 code style,边界条件的判断,哪怕是注释情况,都能看出一些编程习惯。我认为这个环节对于招聘一个写代码的工程师来说,肯定是一个必不可少的环节(google 整个就搞了五六轮)。

现场面试

电话面试通过后,HR 会很快跟你反馈沟通面试结果,是否通过,以及 onsite 的安排。因为现场面试是 4-5 轮,平均1 轮一小时的话,需要 4-5 个小时,其实还是蛮耗费精力的。

一般会沟通可以约 2 个半天或者 1 整天,两个半天的好处是,时间不会那么紧张,前两轮后,中途可以过几天再休整调整下再继续。我当初就选择”快刀斩乱麻/早死早超生” 的方案直接约了 1 天时间搞定。

onsite 也基本上是在电脑上 coding。你和面试官一人一个笔记本,coding时共享屏幕,有时候题目面试官会在白板上写出。onsite 的题目,明显就要比电话面试的题目难度高一些呢。但实际上比我想象中的要简单些。

因为曾经想 Google 这样的公司面试恐怕连理解题目意思都要理解大半天吧。可能也是社招的缘故,社招整体感觉在算法的要求比校招就要低一些。这只是我的主观感受啦。(确实自己在当面试官的过程中,在算法这块对社招的同学预期也会低一些)

我记得其中有一道题目就跟 leetcode 上的类似(再次声明不是原题,也不 share 原题),leetcode 上那个题目应该是二维矩阵,最短路径相关的。用 dp 可以解决。只不过,一般题目会分为好几个小问题,难度一般从易到难。

同时也考察到了二叉树,仍然围绕着二叉树的遍历进行。需要熟知二叉树的各种遍历方式,非递归的方法(递归比较容易,一般不会让写这个)。在遇到二叉树相关问题的时候,是否可以联想到二叉树的遍历上来。

另外有一道系统设计的问题,“知识图谱”的概念,围绕着”图”的相关算法,这个要求在白板上写出设计方案和伪代码。同时面试官会不断 push 你让你提出更优的解决方案。有足够多的计算资源,并行去跑,以及具体怎么实现。这道题目我回答的不好(当初也知道不好,后面 HR 反馈也印证了这一点)。

还有一道题目,是解决生活中的场景题目。需要你抽象出这个问题,用代码来解决。一般这种题目,就需要反复跟面试官去沟通和确认其中的场景,怎样把业务抽象成算法。记得之前面试 Amazon 的时候也有类似的题目(只不过当初面 Amazon 考察的是 OO Design,而本题是具体算法实现)。

onsite 一共聊了 5 轮,上午 2 轮,下午 3 轮,其中有两轮是英文面试(英文面试后面会说)。整体来说,工程师岗位面试会围绕如下几个方面进行(以下参考 HR 提供的面试指南):

Coding: 用熟悉的编程语言(不限)实现给定的题目。会重点关注解题目过程中的理解和沟通能力;

算法: 涉及到 排序/搜索/分治/动态规划/贪心/递归,具体数据结构,以及也有可能会涉及到 Dijkstra 和 A* 等算法,需要会算法复杂度的分析;

排序: 常见的排序算法,时间/空间复杂度,例如 快排/归并/堆排序/插入/基数排序等等;

数据结构: 数组/连表/堆/栈/hash/数/二叉树等;

数学: 可能会涉及到离散数学,组合数学,例如 N个中选k 个的方法等;

图: 图的表达(例如矩阵/邻接表),bfs/dfs 等;

递归: 递归和迭代的转换;

其他: 设计和操作系统等;

以上这部分摘自 HR 提供的 Google 工程师面试指南。pdf,有需要的同学(再次强调已和 HR 确认,此资料可共享),从公众号后台回复 “Google面试指南+邮箱”,我会发送给你(或者直接扫码加我微信也可以)。

午饭

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

  • 10
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值