程序员面试需要注意的地方

(此文来自乐字节)

有个现在在咱乐字节的同事,之前跟我说了下他在Google的面试经历;今天想起来整理整理下,以我同事的亲身口述分享给大家。

去年换工作的时候, 面试了一下 Google, 来了个 Google 面试六轮游, 结果是没通过。

现在分享下我参与面试的具体流程以及个人认为应该注意的事项, 希望对大家有所帮助。

个人相关背景

先介绍下自己相关背景, 985 本科, top2硕士(其实, 大公司都比较看重第一学历的). 在校期间, 科研也没啥能拿得出手的论文. 社招时, 4 年多工作经验, 面试时为大疆后端开发TL(带3~4个人而已)。

面试流程

Google 整体面试流程上基本如下:

我一共经历了 1 轮电话面试, 5 轮 onsite, 如果算上前面的HR 的预筛选的话, 就是 7 轮。

简历投递

之前校招其实也参加过, 无奈门槛太高, 竞争压力太大, 连面试流程都木有进。

当初校招时直接网上刷题, 这个网站上其实还能看到往年的一些题目情况: 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。

你和面试官一人一个笔记本, code 时共享屏幕, 有时候题目面试官会在白板上写出。

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 等;

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

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

英文面试

英文面试, 单独拿出来说一下。

建议还是提前准备, 练习一下基本的口语. 不要因为面试过程中, 突然让你只用英语沟通, 让气氛变得紧张起来, 导致发挥不好. 自我介绍之类的肯定你可以提前准备, 然后就是你可以尝试比如拿其中的题目自己模拟一下面试场景. 主要是可能需要提前熟悉一下基本的计算机相关词汇, 不要到时候想表达确表达不出.

整体来说, Google 的面试确实很难, 但确实也没我想象中的那么难. 但要求确实是很高的, 基本上一些边界 case 等也都是在考察范围内的. onsite 面试完后, 在第二天, 我就得到结果通知, 面试没通过. 事实来看没通过的结果反馈比通过反馈更快图片. HR 会反馈你哪里表现得不够好, 然后如果想进 Google, 就加油刷题, 说 1 年后, 可以再次尝试, 保持联系哦.

哈哈, 以上就是我这次完整的 Google 面试之旅, 虽然失败(实力还不够)了, 但还是有收获的. 如果大家有足够自信(当然也要有一定实力哈), 也可以找我帮忙内推, 我可以给在 Google 的同学帮忙或者直接给招聘的 HR 同学. 如果要面试 Google, 刷题是在所难免的了. 整体来讲, Google 的面试体验还是很不错的, 全程 HR 小姐姐悉心指导和及时反馈, 给 HR 小姐姐点赞.

PS:阿里P8强烈推荐的8个Java项目实战大合集 B站:BV1J64y1R7UN

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容