嘗試在自己的博客上搜索點(diǎn)東西,結(jié)果發(fā)現(xiàn) 4 年多以前還在博客上寫(xiě)過(guò)一系列的 recruiting events,把大四時(shí)候參加過(guò)的各種筆試面試都記錄下來(lái)了。我從去年準(zhǔn)備離開(kāi)百度開(kāi)始,到現(xiàn)在總過(guò)面試過(guò) 4 家公司:Google、Microsoft、Yahoo、Facebook,原本去年也想把面試經(jīng)驗(yàn)寫(xiě)一寫(xiě)的,結(jié)果一拖就拖到現(xiàn)在。我不想寫(xiě)面試經(jīng)驗(yàn),因?yàn)槲覀(gè)人不喜歡漏題和背題的做法。我自己作為面試官,知道要設(shè)計(jì)出來(lái)一道好用的題目有多難,所以我希望面試者都是如實(shí)表現(xiàn)自己解題能力的。我更喜歡寫(xiě)面試體驗(yàn),就是在整個(gè)面試過(guò)程中一家公司給人的印象是怎樣的,HR 和面試官是否專(zhuān)業(yè),能否讓人信服這是一家值得長(zhǎng)期工作的公司。
我想寫(xiě)的第一家公司是 Google,因?yàn)樗俏以谙胍x開(kāi)百度時(shí)第一家聯(lián)系到我的公司。2012 年 12 月底的某一天早上,我突然感覺(jué)到我應(yīng)該離開(kāi)百度,因?yàn)槿绻@個(gè)時(shí)候已經(jīng)沒(méi)有勇氣離開(kāi)這家公司了,很可能就不會(huì)再想要離開(kāi)了。當(dāng)天中午在百度大廈西餐廳吃午飯,接到一個(gè) Google 上海 HR 的電話(huà),問(wèn)我有沒(méi)有興趣去面試,我想既然你打電話(huà)來(lái)的時(shí)機(jī)那么好,我就答應(yīng)你去面試吧。(在那一天之前,我對(duì)獵頭的標(biāo)準(zhǔn)回復(fù)是「有美國(guó)或者香港的職位嗎?」)她問(wèn)我將來(lái)希望在北京還是上海工作,當(dāng)時(shí)我對(duì)北京的厭惡程度還沒(méi)有現(xiàn)在那么高,同時(shí)覺(jué)得搬家到上海又比較麻煩,于是就說(shuō)在北京,接著我就變成跟北京 HR 溝通了。
Google 的 HR 會(huì)負(fù)責(zé)做兩件簡(jiǎn)單得不需要面試官做的事情,這能夠很好的提高招聘流程的效率。第一件是確認(rèn)你能夠適應(yīng)工作環(huán)境中的英語(yǔ),為此 HR 要我用英語(yǔ)跟她對(duì)話(huà)兩三分鐘,主要就是讓我說(shuō)說(shuō)工作經(jīng)驗(yàn)和其中的亮點(diǎn)。習(xí)慣在私企工作的人不要以為外企對(duì)英語(yǔ)的要求很高,其實(shí)大多數(shù)長(zhǎng)期在中國(guó)工作的人說(shuō)話(huà)或者發(fā)郵件都會(huì)很 Chinglish 啦,所以關(guān)鍵是要敢于用英語(yǔ)進(jìn)行溝通。
然后 HR 發(fā)了一個(gè) Codility 的地址給我,讓我有空抽時(shí)間去做題。一個(gè)小時(shí) 3 道難度相當(dāng)于 OI 基礎(chǔ)題的題目,平均 20 分鐘一道。最簡(jiǎn)單的題目一看就知道是 O(n) 能解決的,最復(fù)雜的題目看上去是 O(n^2) 但想一下就能優(yōu)化為 O(n log n)。對(duì)于有算法訓(xùn)練背景的人來(lái)說(shuō),這樣的題目會(huì)讓人感覺(jué)到很有把握。對(duì)于沒(méi)有經(jīng)受過(guò)算法訓(xùn)練的人來(lái)說(shuō),掉進(jìn)陷阱里是很容易的。很可能沒(méi)有把 O(n^2) 優(yōu)化為 O(n log n),結(jié)果超時(shí);可能沒(méi)仔細(xì)看題目說(shuō)明的數(shù)值取值范圍,某些變量選錯(cuò)了數(shù)值類(lèi)型,結(jié)果溢出?紤]到 Google 重視算法的程度,再加上 Google 中國(guó)面試的額外難度,算法訓(xùn)練還是很必要的。
匹茲堡的Google新辦公室
在我通過(guò) Codility 測(cè)試后,HR 問(wèn)我了對(duì)題目難度的反饋,然后約了一輪電話(huà)面試,并且告知面試主要圍繞算法、數(shù)據(jù)結(jié)構(gòu)、系統(tǒng)設(shè)計(jì)、編碼來(lái)進(jìn)行。Google 面試的格式都很固定,45 分鐘內(nèi)期望你能做出 3 道題來(lái)。這 3 道題最起碼要能把人人都能想出來(lái)的「笨辦法」用代碼寫(xiě)出來(lái),否則會(huì)讓面試官感到不滿(mǎn)意。如果有些題目能夠比較快地做出來(lái),面試官就會(huì)讓你優(yōu)化。就算你第一次給出的答案已經(jīng)是業(yè)界已知最優(yōu)解,面試官都還是會(huì)讓你優(yōu)化,因?yàn)檎l(shuí)也不知道有沒(méi)有人能在面試過(guò)程中突然爆發(fā),想出一些過(guò)去沒(méi)人想到過(guò)的解法。如果面試官心中已有優(yōu)化的方案,在你想不出優(yōu)化方案時(shí)他可能會(huì)給你提供一些提示。
一輪電話(huà)面試后,HR 就開(kāi)始約到 Google 辦公室的面試了。第一次約了下午 3 輪面試,還是那個(gè)很固定的格式:每輪面試 45 分鐘,兩輪間隔 15 分鐘。整個(gè)面試流程讓人感覺(jué)到很人性化:在 Google 簽到后,HR 會(huì)先帶你去 kitchen 拿點(diǎn)吃的喝的,然后把你帶到面試所用的會(huì)議室。多輪面試的話(huà),HR 中間還會(huì)來(lái)問(wèn)一下你要不要去洗手間,或者多拿兩瓶水。面試完畢后 HR 會(huì)來(lái)問(wèn)你感覺(jué)如何,同時(shí)也會(huì)讓你知道面試官的初步反饋是否跟你的感覺(jué)一致。我在 3 輪面試中有一輪感覺(jué)不太好,因?yàn)槊嬖嚬僦唤o了 2 道題,并且我最終都沒(méi)辦法解出來(lái),HR 也確認(rèn)了就是這一輪的反饋不好。
此外,Google 的招聘流程還讓人感覺(jué)到很有效率。作為面試官,我也知道自己寫(xiě)面試反饋有多喜歡拖延,而且公司填寫(xiě)面試反饋的系統(tǒng)越不人性化我就越想要拖延,然而公司內(nèi)部系統(tǒng)做得人性化的又實(shí)在罕見(jiàn)。Google 的面試基本上隔天就有結(jié)果,然后 HR 就會(huì)約下一輪的面試。因?yàn)槲以诎俣鹊臅r(shí)候每周哪個(gè)時(shí)間沒(méi)有會(huì)議是很確定的,所以我總是選擇下周同一個(gè)時(shí)間段來(lái)面試。在經(jīng)過(guò)總共 4 輪面試后,HR 說(shuō)因?yàn)榍懊嬗幸惠喌拿嬖嚬俜答伈缓茫韵M偌右惠喢嬖。因(yàn)榍懊娣答伈缓玫拿嬖嚬俦容^ senior,所以這次找了一位同樣 senior 的面試官來(lái)面試,于是我又去了一次 Google 辦公室。