Google面试总结

2023-05-16


分享

Google面试总结来源: 王冠中的日志

 

终于把Google的面试给搞完了,感觉可以算是Tech Interview的顶峰了。这里主要写一下大概流程和内容,给大家以后interview一个参考。

G的full time面试一般3个,2个phone+1个onsite。到我这儿只有1个phone的,原因不太清楚,可能是他们急着招人,也可能是Waterloo Master的牌子,反正少一个我也乐的省心。从开始递简历开始到email接触到最后onsite完差不多快2个月。这个速度似乎在大公司里面算快得了,反正至今MS啊Amazon啊这些都还没理我……

 

先说说所有用到的知识点吧。Google的面试题总结起来2个词:宽!深!覆盖的知识面之广,基本把我知道的全给挖出来了。然后最后都会考到很难很难的点上,杀个几百万脑细胞。总的来说,我面试用到了以下所有的东西

Data Structure:

  • Linked List
  • Tree / Binary Search Tree
  • Vector / ArrayList
  • Queue & Stack
  • Heap
  • Stream (以前完全没用过这种东西啊!!!!)

Algorithm:

  • Output Sensitive Algorithm
  • Dynamic Programming
  • String Matching / Auto-Completion
  • Merge of Sorted Lists (2 or more)
  • Random Generation
  • Avg. and Wostcase Runtime / Space Analysis

Others:

  • Polymorphism
  • Design Patterns
  • Huffman Optimization (这个都快忘了)
  • Architechture Design
  • Exception and Handling (这个完全给跪了)

 

基本就这些了。有些东西真的是太久没见过,都忘了。还有些东西想都没想过。Onsite最后一个人一上来问说:Suppose I dereferenced a random pointer in C++ program, and then I got an error and back to OS, can you tell me what happened there? 我当时整个人都囧了,这NM简直是结合了Complier, Exception和OS等多个方面的问题,太综合了点吧!

总的来说,一般都会有好几个面试官,然后每个面试官喜欢出写跟自己这在做的工作相关的。第一个面试官是搞Speech-to-text的,然后就问了两个word auto complete的问题。然后着重问了些设计上的细节,比如说哪个地方用那种data structure; search的时候用什么algorithm。后面还有面试官直接说“我现在正在用一个神马神马东西,你帮我设计一个”之类的。当然,也可能跟resume有关。我resume上面写了好几个project,碰到类似部门的面试官就会先问我写这方面的问题。

以前看到过很多人说这种tech interview会让你手写code,然后R和YJ也告诉我会写一堆code。本来我蛮紧张的,怕给个难题写出来一堆bug。结果发现,会让你写code的肯定都是简单的题啊!总共写了4段code:

  • Find mininum element in a linked list
  • reverse a linked list
  • merge multiple sorted linked lists.
  • check if there is a cycle in a linked list

这4个的code大二的学生就会写了有没有!前三个我们学校大一就会学有没有!其实我觉得这种code就是考你个基本功,看你是不是会一种编程语言。真正考人的地方还是在后面设计和算法上面,重点还是看你的思考能力。面试官想看到的是,当给你一个你们见过的问题时,你会怎么处理。

 

下面说说面试流程。先说电话面试吧。网上都说电话面试的时候会先问点behaviour question,来缓解一下紧张的气氛。关于这点,我只能说:呵呵~。我电话面试就是:hi Wendell? OK, Let's start. Tell me some detail you did in this project...说好的behaviour question呢?这简直是直入正题,连寒暄都没有!

算上onsite的4个面试官和1个电话面试官,我见过5个面试官。有三个开头是tell me about a project you did (or this project on your resume)。所以说做一些这方面的准备还是很重要的。还好我对自己做得东西还算熟,加上像AI的project专业性比较强,可以没事儿吐几个貌似很高深的专业词汇,装装B还是可以的。建议大家以后面试的时候准备1,2个这种Project,被问到的几率还是蛮大的。

如果开篇没问这些,就是直接进入正题了。一般来说,都会问个问题,然后问你怎么解。如果是个简单的问题,会让你写code。如果是比较困难的问题,多半是不会写code的,而你也会花大多数时间解释。比较经典的流程是给个问题,然后问can you improve this。我现在听到这句话都想死有木有啊!!!因为除非你能给个formal proof说没有更好的算法了,不然面试官会一直问到死啊!当然,另外一点就是what is the runtime。其实这个一般不是很难,但有时候面试官会让你用固定的变量,比如我面试的时候把一个词典做成了prefix tree,然后面试官让我把retrive a subtree的runtime和词典里词的数量联系起来,当时分体的我个蛋疼。当然,还有些时候会让你分析space,还有些时候是worst case and average case……总而言之,建议大家多作这个的练习吧,肯定跑不掉的。

最后说一下,有些面试官会很贱的误导你!我最后一个面试,那个面试官特别拉风,右边脸颊和脖子上有纹身,然后右手背上纹了个“独”字,左手背上纹了个“孤”字。问了我一道random generation的东西,然后试着误导我,说:我给你个提示,你可以这样这样,你不觉得很有用吗?然后我看半天不知道怎么接下去,因为出来的东西都是不对的!最后他告诉我,其实这道题测的是看你会不会让这个random的几率不平均。我擦,还好我是学AI的,半只脚踩在stat上的,不然还真说不定被你匡进去了!

面试的最后,有时候会给你点问问题的时间。据说这个也是面试官看重的一部分。我的一般做法是,问问面试官什么team的,问问他们的产品,问问他们team和其他team的联系。我问过技术相关的地方,好些东西都有保密机制,问不出个啥,还容易尴尬,不如问些什么一星期开几次会啊,要给其他team合作时候怎么办啊之类的问题。

 

最后说说面试题目吧。其实Google的面试题是要求保密的,我也就不说太详细,也不放答案了,你们就当练习题做好了

  1. 给你个BST/Min-Heap,找第K小的数
  2. 前面说的4个linked list problem
  3. 用linked list编一个stack,除了push和pop,还有min(),返回stack里面最小的element
  4. 现在程序要merge n个sorted list,但list很长会花非常多的时间,那我怎样设计程序达到高效率
  5. 假设现在有很大量的数据,99%是8-bit integer,1%是64-bit integer,如何记录这个
  6. given a set of intergers,the range of the set is defined at [low,high] where low is the smallest nubmer in the set and high is the largest number in the set. randomly generate a number such that in (low,high) but not in the set.
  7. Given an array of integers, and a difference d, produce the longest arithmetic progression chain from the array with the given difference.

 

神啊,让Google给我个offer吧

 


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Google面试总结 的相关文章

  • java.lang.NoClassDefFoundError:com/google/common/base/Moreobjects

    项目所属环境不同 解决方案不一定适合所有人 见谅 java lang NoClassDefFoundError com google common base Moreobjects 编译可以通过 运行报错 很无奈 突然蹦出这鬼东西 经过一番
  • 申请带@msn.com后缀的邮箱

    很多朋友总是抱怨申请msn邮箱时总是申请到 hotmail com的 为什么申请不到 msn com的呢 我从网上Google了一下 这个地址是申请简体中文MSN邮箱的 https accountservices passport net
  • eBay架构的思想金矿

    2008年01月24日 星期四 11 53 P M 英文来源 http www manageability org blog stuff about ebays architecture An accurate way of knowing
  • Code For Better 谷歌开发者之声 ——Tensorflow与深度学习

    给大家推荐一款丧心病狂的API测试工具 Apifox Apifox 是接口管理 开发 测试全流程集成工具 定位 Postman Swagger Mock JMeter 点击此处跳转体验 目录 一 TensorFlow简介 二 机器学习与深度
  • 整合google,51ditu和mapbar的地图API

    http blog 163 com goodluck lq 126 blog static 63285386201001994058213
  • 申请带@msn.com后缀的邮箱

    很多朋友总是抱怨申请msn邮箱时总是申请到 hotmail com的 为什么申请不到 msn com的呢 我从网上Google了一下 这个地址是申请简体中文MSN邮箱的 https accountservices passport net
  • 通过智慧的选择保持持续的进步 ——Google全球副总裁李开复谈选择的智慧

    通过智慧的选择保持持续的进步 Google全球副总裁李开复谈选择的智慧 2006 11 21 15 24 57 当今时代和20世纪已经有很大的差别 今天人们可以通过互联网接触到更多的信息 根据这些信息来为自己做更好的选择 这样的环境下 能够
  • zxing二维码的生成与解码(C#)(附例子)

    二维码的生成 using com google zxing qrcode using com google zxing using com google zxing common using ByteMatrix com google zx
  • Android控件之AutoCompleteTextView、MultiAutoCompleteTextView探究

    在Android中提供了两种智能输入框 它们是AutoCompleteTextView MultiAutoCompleteTextView 它们的功能大致一样 显示效果像Google搜索一样 当你在搜索框里输入一些字符时 至少两个字符 会自
  • 11款插件让你的Chrome成为全世界最好用的浏览器|Chrome插件推荐

    文章来源 知乎 收录于 风云社区 SCOEE 提供mac软件下载 更多专题 可关注小编 微学徒 查看我的文章 也可上 风云社区 SCOEE 查找和下载相关软件资源 一 综合类 新买苹果电脑 mac系统中小白应该了解哪些东西 Mac新手必看教
  • 我的春招实习+秋招总结【前端开发】

    双非本科 通信工程 算是转到IT行业这边的了 从大二暑期正式开始学习前端 想想已经一年的时间了 期间经历了很多 从迷惘到清晰 从艰难自学到找到实习 从备战秋招到找到工作 能经历的我都经历过了 来说说那些 前端工作者 的艰辛与欢乐 开始自学前
  • Android:在争议中逃离Linux内核的GPL约束

    原文地址 http tech sina com cn s s 2012 05 28 09447177318 shtml 为这个题材起名 我思考了许久 GPL 是著名的开放源代码许可协议 Linux 内核开源项目正是在 GPL 的庇佑之下 十
  • 中国猎头公司排名 (前十)

    4月3日 平时能够收到不少猎头公司排名评选的邀请 但自己一直怀疑这类排名评选的可行性和公信力 人为因素在这样的评选中占了太大的成分 因为喜欢搜索这个职业 所以我一直是一个谷歌Google的粉丝 Google的成功和深入人心和它坚持自己的 搜
  • 终于搞定了部分网站无法打开的问题

    最近机器出现一个烦人的问题 有些网站无法打开 最初以为是实验室网络的问题 后来发现别人的机器能打开 于是开始折腾自己的机器了 hosts文件没有异常 关掉杀毒软件 防火墙 症状依旧 在浏览器地址栏中敲入url回车之后 浏览器很快报错无法访问
  • ubuntu software center have problems,it cannot run.

    When I update my ubuntu 11 10 I meet this problem like following Items cannot be installed or removed until the package
  • 制作一份简单的网络地图(世博地图的配准和切割)

    其实我很早的时候就写过一篇 我的 2010世博地图1 0版发布 但没有和大家做明确的说明和制作方法 今天就和大家一起来分享地图配准和地图切割并进行网络发布的问题 其实就是以世博为例制作一份简单的网络地图 网络地图是以Google Maps
  • 30个适合女生玩的可爱网站

    ugmbbc发布于 2008 03 20 13 30 12 2905 次阅读 字体 大 小 打印预览 感谢不要笑我的投递这次推荐给大家的都是非常好玩和可爱的网站 他们都拥有不错的技术和创意 这些网站尤其适合女孩子玩 当然cnBeta是一个罗
  • Google C++风格指南 阅读笔记

    这个Google C 风格指南出得太好了 有很多C 的问题 其实通过阅读这份文档就可以了 相信读完后 可以在简历上加上一句 具有良好的编码风格 哈哈 下面记录一下我的读书笔记吧 整份文档的中文版本我已经上传到了资源里面 1 头文件 1 1头
  • Google Protocol Buffer 的使用和原理

    Google Protocol Buffer 的使用和原理 刘 明 软件工程师 上海交大电子与通信系 简介 Protocol Buffers 是一种轻便高效的结构化数据存储格式 可以用于结构化数据串行化 很适合做数据存储或 RPC 数据交换
  • Google人机认证解决方法

    针对Chrome浏览器 下载gooreplacer 下载地址1 下载地址2 安装 gooreplacer crx Chrome无法从该网站添加应用 扩展程序和用户脚本 将 crx后缀改为 rar 之后开发者模式安装 重定向网址 重定向 将网

随机推荐

  • ViewBinding和ButterKnife

    一 ViewBinding和ButterKnife比较 xff1a 传送门 1 ButterKnife一个好处就是不用写findViewById xff0c 另一个好处就是不用写setOnClickListener之类的 xff0c 满屏幕
  • 图的密度公式的解释

    一直不明白 xff0c 图的密度公式的含义 xff0c 如图所示 xff1a 分母 xff1a n n 1 2 xff0c 其实可以理解为两两相连的组合数量 比如说有6个节点 xff0c 那个两两相连的组合数为6 5 2 61 15 分子自
  • 【论文阅读】Cancelable Iris Biometric

    1 介绍 如果同时使用密钥和虹膜生物测定 xff0c 则错误拒绝率将增加 xff0c 因为恢复的密钥和汉明匹配距离都受到来自虹膜图案的噪声的影响 2 方法论 2 1 免注册转换 xff08 Registration free transfo
  • 阿里云服务器VNC连接Timed out waiting for a response from the computer报错解决方案

    首先要说明一点 xff0c 如果你是初学者 xff0c 第一次使用阿里云服务器并想获得可视化界面过程中遇到连接问题 xff0c 你可以参考以下方案 因为想要处理网页自动化测试的同时查看效果 xff0c 所以我想搞个VNC Viewer来显示
  • 发现scikit-image

    我是图形方面的新手 xff0c 写错的地方还请大家勘正 不记得从哪看到openCV与python的东西 xff0c 突然产生兴趣 xff0c 我喜欢python3 xff0c 但openCV偏偏最高只有python 2 7的支持 openC
  • Jetpack的学习

    一 ViewModel ViewModel的一个重要作用就是帮助Activity分担一部分的工作 xff0c 专门存放关于界面相关的数据 只要界面上能看到的数据 xff0c 都应该存放到ViewModel中 另外一个很重要的特性就是当手机屏
  • 【centOS 7一个解决“network.service: control process exited, code=exited status=1”方法】

    当我们用finalshell时 xff0c 发现连接不上 xff0c 用ip addr查看时 xff0c ens33没有ip xff0c 查看日志 一开始以为是没有开始网卡 xff0c 于是进入修改网卡配置参数 xff0c 修改 ONBOO
  • Ubuntu 20.04桌面文件夹图标消失及文件系统无法打开

    前言 之前遇到过服务器上桌面图标突然消失的情况 在更换系统语言之后 xff0c 桌面出现过一次这种情况 xff0c 经过重启之后就恢复了 再后来又莫名其妙出现了这么个问题 xff0c 最开始搜索的解决方案是 让你打开任务管理器 gnome
  • vim打造最强systemverilog编辑器

    更多分享内容可访问我的个人博客 https www niuiic top 更新 xff1a 1 对自动补全部分进行加强 xff0c 可以无限自定义snippets和keywords 补全能力完胜vscode 2 使用svlangserver
  • 修改CentOS VNC分辨率

    修改VNC分辨率有两个地方 1 etc sysconfig vncservers 2 usr bin vncserver 有些机器直接设置了这里就行 xff0c 有些要通过设置2才行
  • Debian11系统安装与配置Elasticsearch7.17.6

    安装方式 xff1a 使用安装包进行离线安装 1 下载安装包 下载地址 xff1a Elasticsearch 7 17 6 Elastic 选择DEB X86 64 xff0c 下载后得到文件elasticsearch 7 17 6 am
  • Windows Server 2012 R2 管理员密码忘记如何修改密码

    管理员密码忘记如何修改 人非圣贤孰能无过 有时我们经常会遇到忘记密码的尴尬场景 尤其是本机的管理员密码忘记 xff0c 那么如何更改恢复呢 xff1f xff08 如果你安装系统的过程中本身没有设置过密码 xff0c 那密码就为空或者为Ad
  • XPath 简单语法 (三)

    XPath表达式 2008 02 27 16 55 XML 文档对象模型 DOM 能够以编程方式读取 处理和修改 XML 文档 XPath 表达式 XPath 表达式使用路径表示法 xff08 与 URL 中使用的路径表示法类似 xff09
  • Error: cannot open display: localhost:0.0

    https stackoverflow com questions 12356425 error cannot open display localhost0 0 trying to open firefox from centos 6 在
  • MySQL 5.6 源码目录结构

    基于MySQL 5 6 26源码 源码目录 xff1a BUILD 构建工程的脚本 client 客户端 cmake cmd line utils 命令行工具 dbug 调试库 Docs 文档 extra 一些相对独立的次要工具 inclu
  • 计算机I/O原理

    cpu通过IO命令控制设备 xff0c cpu对设备的控制仅仅可以到达设备控制器 xff0c 无法直接控制设备 设备无法直接和cpu通信 xff0c 设备控制器通过中断机制向cpu反馈信息 即这个一个模型 CPU IO指令 gt 设备控制器
  • 计算机的I/O端口地址表

    PC的I O端口地址表 xff08 I O端口地址表 xff09 http tieba baidu com f kz 61 16042340 I O端口地址表 PC只用了10位地址线 A0 A9 进行译码 xff0c 其寻址的范围为0H 3
  • 利用pthread进行数组求和

    POSIX thread 简称为pthread xff0c Posix线程是一个 POSIX 标准线程 利用多线程可以提高运算速度 利用pthread进行数组求和的程序如下 xff1a include lt stdio h gt inclu
  • 字符串的全排列程序

    include lt iostream gt include lt cstring gt using namespace std void swap char str int i int j char tmp 61 str i str i
  • Google面试总结

    分享 Google面试总结 来源 xff1a 王冠中的日志 终于把Google的面试给搞完了 xff0c 感觉可以算是Tech Interview的顶峰了 这里主要写一下大概流程和内容 xff0c 给大家以后interview一个参考 G的