1. 程式人生 > >一個計算機畢業生的求職經驗

一個計算機畢業生的求職經驗



微軟:
題型只有二十道不定項選擇題,難度較難,要求在一小時四十分鐘完成。難度較難,覆蓋面非常廣,從設計模式,演算法分析,程式碼閱讀到C++語言特性,甚至連冷門的函式式程式設計語言都有涉及。

微軟的筆試題目BT之處在於其獨特的積分機制:答對了加分,不答無分,答錯了倒扣。這就使得很多ds答完試卷感覺自我良好但實際已經被倒扣出翔。以最後一道題為例,答對了加7分,答錯倒扣13分,相當於一下子損失20分。所以微軟的筆試題會做就得做對,不會做就別蒙,要不更慘。

此外,微軟的筆試題是英文的,加上時間比較短,有些人題都讀不完,有些ds連functional language是什麼都不知道,自然敗的很慘。

雅虎:
題型由十餘道單項選擇題,一道設計題目和六道演算法題目組成,其中六道演算法題目是六選二,要求在兩個小時完成。難度尚可,主要考察程式設計能力和演算法設計能力。由於時間充裕,儘管是六選二,為了炫技,我直接答了裡面的五道題目。然而面試時發現面試官判卷子時並沒有把多答的題目考慮在內,囧tz。

相對於微軟,雅虎的題目覆蓋面就窄了許多,沒有一道題目跳出程式設計、演算法和作業系統這個圈的,只要勤加準備,很容易通過。

雅虎的筆試題也是英文,因此英語作答較為合適,此外,由於演算法題目簡單,給出optimal solution是必須的,比如說在logN的時間內算fibonacci number是必備的知識,能寫binary search就不要寫sequential search等等。

從筆試題可以明顯看出,國外的大型IT公司(比如雅虎,微軟和谷歌等)並不在意你現在的skill set,而更看重你的potential,因此題目大多很基礎,並具備相當的深度,以確保你對CS有深刻的理解並能夠走的很遠;而國內的IT公司(比如百度、搜狗和人人等)更看重你現在的skill set,因此會出現不少語言特性,OS操作之類的具體題目,以確保你能夠以儘快的速度上手幹活,至於能發展到啥程度他們就不care了。

因此,準備筆試題的時候要確定自己的目標公司:主攻國內公司的話,C++的語言特性、linux基本命令操作這些細節也得準備,因為會有大量此類題目;主攻國外公司的話,良好的英文閱讀能力必不可少,此外優秀的程式碼理解和程式碼編寫能力也不可或缺。

此外,不要在筆試題目裡犯低階錯誤,不要抄襲(面試時經常會問到筆試題),保持書寫的工整(尤其是程式碼題目和問答題目)。

考慮到幾乎所有的公司都有程式設計題目,也就是在紙上寫程式碼,這裡推薦幾本相關書籍:

1、Elements of programming style 2nd,寫出良好風格的程式碼。紙上程式碼一般不長,但短短几行程式碼往往可以看出這個人的水準,風格很差的程式碼往往會被pass掉。

2、Algorithm design manual 2nd,作為非ACM出身的碼農,這本書比算導實用很多,課後題也很實在,對回溯,動態規劃這些程式設計技巧講的非常清楚。

3、C interfaces and implementation,無論是面試還是筆試,一般都會用C寫程式,這本書包含大量的工業級C程式碼,絕佳的參考和模仿素材。

最後推薦下Elements of programming和Structure and interpretation of computer programs,這兩本書難度很搞,需要大量的時間閱讀,不適合臨場閱讀準備,但讀過後,寫出的程式碼絕逼會上兩個層次,這裡我就不多介紹了。

6、面試

之前有人PM我關於海投簡歷的問題。我個人不建議海投簡歷。因為對能力弱的人來說,海投簡歷只會讓他信心更差,沒有任何效果,有投簡歷的時間還不如精心準備少數幾個好公司;而對能力強的人來說,海投簡歷之後會有大量的筆試和麵試,筆試很耗體力,面試更很耗體力,不但需要打車或坐地鐵在各個公司間穿梭,而且需要在面試時保持精神的高度集中,一般面下來都會精疲力盡,導致接下來的發揮不好。所以還是之前所說,優先內部推薦,然後再根據自己的情況和職業發展路線選擇公司,選擇職位,不用選太多,集中精力攻破領域內的TOP3即可。就我自己而言,求職期間,我一共投了12封簡歷,參加了12家公司的面試,一共面了35輪。說多不多,說少不少,因為自己投簡歷時也是本著網際網路公司為主,小公司和企事業單位壓根沒有投,精準投放的好處在於可以集中精力準備同一型別的公司,從而達到不錯的效果。

關於簡歷海投的問題就說到這裡,接下來講講IT公司的面試。需要注意的是我這裡聊的都是應屆生面試,社會招聘面試可能會有所區別,但整體流程不會有太大差異。

儘管筆試題會有所差別,但IT公司面試的流程大同小異:標準的技術面試一般有45分鐘到60分鐘,大約分為三個階段:

1、自我介紹(5~10分鐘):

這個環節的主要目的在於建立面試官和求職者之間的溝通,面試官已經掃過你的簡歷,但需要對你有進一步的瞭解,以便建立一個初步印象,並便於進行接下來的技術提問,所以這個環節最常見的問題無外乎“進行一下自我介紹”,有時會加上3分鐘或是5分鐘的時限,有時會詢問“說說你最得意的專案/作品”之類的變體問題。

由於這個環節相對固定,因此準備起來相對容易,但即便如此,面試初期時我在自我介紹環節也犯過不少錯誤。這裡以我的經歷簡單的總結下這個環節的要點:

1、言簡意賅,突出亮點

面試初期時,我犯的一個很大的問題就是自我介紹廢話太多,諸如“出生自xx省xx市”,“自我評價xxx”之類的屁話連篇。要知道技術面試不是相親,這裡的自我介紹不是相親裡面的查戶口本,而是要了解你這個人靠不靠譜,牛逼不牛逼。如何在3分鐘內讓別人覺得你牛逼呢?很簡單,說且僅說你最牛逼的事蹟,讓對方留下深刻印象。就技術面試而言,牛逼的事蹟包含三方面:做過的專案,讀過的書,認識的人。

如果實在想不出來有啥牛逼事蹟,那就比較難辦。說實話,換做你是面試官,招一個履歷毫無亮點的人進來有何用?

2、緊貼簡歷

面試官瞭解你的另外一個途徑就是簡歷,然而短短一兩頁的簡歷很難說明白你簡歷專案中的亮點和難點。就算你不提及,面試官也會在簡歷中挑他感興趣的點進行提問,因此自我介紹的內容應該是簡歷的補充。這樣既能留給面試官不錯的印象,也能有效節省時間,留出更多的時間進行技術提問環節和問答環節。

此外,千萬不要搞出自相矛盾,比如說簡歷講的做了A你在自我介紹中又說是B,這就不是拙計的問題了。

3、瞭解公司需求

不要試圖用一套自我介紹來搞定所有公司,除非你的簡歷只有一句話("Exhausted graphic programming"或是"I wrote python"等)。不同的公司有不同的需求,在Google面前大談.net技術顯然不是什麼好的選擇(我在google一面中就做過這種挫事)。面試之前要進行詳細的調研,瞭解公司和職位的需求,然後根據他們的需求定製自己的自我介紹和簡歷,效果會更好。


2、技術提問(35~45分鐘):

通過自我介紹環節,面試官會對你有一個大概的評估,接下來會通過一系列深入的問題考察你的專案經歷和技術能力。所以自我介紹環節不要吹牛逼,技術面試是很實在的東西,你有幾斤幾兩問幾下就出來,根本忽悠不過去。

按照MS的分類,技術面試問題分為三類:

1、Behavior questions:此類問題針對面試者的過往經歷,一方面考察面試者的表達能力和實際經驗,一方面也可以排除掉一堆在簡歷上吹牛逼的真ds:
“說說你最牛逼的專案?”

2、Hypothetical questions:此類問題會假設出一些場景,讓面試者進行作答,主要考察面試者的應變能力和實際經驗:

“給你三天,你會如何把xx專案做得很牛逼?”

3、Probing questions:如果前兩類問題答的不錯,面試官往往會追加一些問題,以探測面試者能夠走多遠,此類問題的出現也是一個標誌,面試官對你之前的表現感覺還不錯:

“你會如何改進你做過的最牛逼的專案?”

就具體技術問題而言,考察題目視你的應聘職位和你的過往經歷而定,開發崗會側重程式碼編寫和系統設計,測試崗會更注重測試用例的編寫等細節,產品崗要對線框圖,互動設計有了解。不過演算法設計和程式碼編寫這兩塊是肯定有的,畢竟這是程式設計師的看家功夫,這個搞不定就沒有然後了。

演算法設計這塊我就不多說了,不搞ACM的碼農沒啥發言權。程式碼編寫的話這裡多說兩句:和平時的開發不同,面試時的程式碼往往是在紙上搞的,而非IDE。很多程式碼寫的還不錯的選手往往會在紙上程式碼這個環節被虐的翔尿齊飛,限於篇幅原因我就不多介紹紙上程式碼的技巧了,還是那句話,多練習。我自己把Software Tools、Elements of programming和C interface and implementation中的程式碼在紙上寫過幾遍,又把常見的面試題目練習了三遍,因此紙上程式碼環節從來沒出過問題。

3、問答環節(5~10分鐘):
如果前兩個環節進展順利,就會進入最後的問答環節。這個環節面試官一般會讓面試者提幾個感興趣的問題,以增進相互的瞭解。

相對於前兩個環節,這個環節會輕鬆很多。不過依然要注意,關於面試表現的問題最好別問,因為問也問不出來什麼,至於待遇,那是HR的事情,技術面試官也無能為力。

最後根據自己的面試經歷說說幾個細節的問題

態度:記住你是去求職,證明自己的能力達到職位需求是你的首要任務。沒有必要和麵試官擡槓,把面試官搞不爽對你一點好處都沒有。我在面試搜狗時就出過這問題(直接表示對面試官的問題的不屑),直接一面被砍掉。

著裝:儘管IT公司大多不需要西裝革履,但也別太拖沓,穿整齊些,至少給人很精神的感覺。我面試騰訊時直接搞了一件套頭衫+迷彩褲+機車帽,結果是面試官從頭到尾就沒正眼看過我,直接一面被砍掉。

交流:面試是一個交流的過程,不明白的一定要主動詢問,面試的大忌就是面試官給了一個問題,你一聲不吭的搞了一個小時,最後發現搞的不是面試官問的問題,這時就算你很牛逼,面試結果往往也是悲劇。

7、國企
國內的IT公司一共去了6家,拿到6個offer,面試19場。
百度(2輪面試+1輪終面)
百度的應屆生面試分為3輪,2輪技術面和1輪終面,3輪面試連在一起進行,如果搞到第1輪或第2輪就叫你回去,基本上不是悲劇就是備胎。如果進了終面,只要不出岔子,一般問題不大,因為百度每年招的人非常多,印象裡有1500人之多。

可能是招的人特別多從而導致面試官人數不夠,百度的面試在所有大公司裡面幾乎是最隨意的,面試官往往都沒有經過系統的面試培訓,出的題目也只是從網上東拼西湊,比如像C++的虛擬函式的實現機制此類SB題目層出不窮。而且有些面試官缺乏對面試者最基本的尊重,我有幾個同學在百度面試時差點被面哭。

就我個人而言,我先後參加了百度的實習生面試和正式員工面試。正式員工面試給我感覺相當不錯,流程很規範,面試官很nice,問的問題也說的過去;然而實習生面試那兩個人就是翔,不但問的問題很二,而且不給我任何交流的空間,同時在面試過程中表現出一副非常不屑的神情,令人極度不爽。

此外,百度的員工(包括面試官)給我一種工作過度的感覺,說驚悚些就是印堂發黑。結合豔紅哥提到的狼性精神,我這號醬油男說啥也不敢去。

搜狗(2輪面試)
搜狗的應屆生面試分為4輪,2輪技術+1輪HR+一輪Manager,4輪面試是分開的,所以會比較麻煩,畢竟來回跑來跑去的很費時費力。
我的搜狗面試經歷比較詼諧,儘管面了2輪,但2輪都是一面,第一個一面是朋友幫忙推薦過去的面試,第二個一面是參加搜狗筆試獲得的面試機會,從這裡多少能看出搜狗招人是有點混亂的。
第一個一面非常囧,當時面試官問我C++,我表示很少用,接下來問了若干智力題,由於被問的有些拙計,於是反問“這種智力題有什麼考察度,會做的人一下子做出來,不會做的一天也搞不定”。估計這句話把面試官搞毛了,接下來的氣氛變的很緊張,後來面試官反問我“那你覺得應該怎麼招人”,我回答“你們應該學學微軟”。然後就沒有然後了,囧tz。
第二個一面感覺還成,因為我筆試的題目答得比較出彩。接下來是一個strcpy的紙上程式碼和一個簡單的OS生產者消費者問題,答得還算順利,可惜依然沒有然後,我懷疑可能是沒有Hire Count了。

搜狗面試給我一個很大的教訓,就是別裝逼,求職就是求職,別和麵試官擡槓。在接下來的面試中,我收斂了很多。

創新工場(2輪面試+4輪終面)
創新工場本身是一個孵化公司,它的招聘流程是這樣的:工場進行筆試和麵試初選,然後由工場下面的子公司進行復選,由於子公司眾多,因此工場有一個雙選會,每個通過初選的求職者可以選擇3家工場的子公司,在這個雙選會上開復哥很是鼓吹創業,不過效果似乎不太理想 :-D
工場的初選面試有兩輪,然後是3個子公司的複選面試。和其它公司不一樣,工場的面試時間非常短,只有25分鐘:一個自我介紹,兩個無需寫程式碼的題目。有點拼人品,因為這麼短的時間很難考察全面。複選面試大多是電面,比較簡單,演算法題目說下思路就可以。順便推薦下友盟,感覺這些子公司裡面這家的發展潛力最大。

騰訊(1輪面試)
騰訊的應屆生面試的組成我不太清楚,因為1輪就GG了。
騰訊的面試也讓人很火大,面試官直接拿一個laptop在那裡給你放ppt,一個slide一個題目,答完下一個slide,結果是我說的口乾舌燥面試官還沒說兩句話。題目五花八門,從簡歷到智力題再到為人處事,印象裡答了不下七八道題目,累的一逼還沒通過,尼瑪。

不過騰訊的面試中見到很多PLMM,目測有很多非技術崗。

人人(2輪面試+2輪終面)
人人的應屆生面試一般是2輪面試+1輪終面,由於我的筆試和麵試發揮不錯,因此又得到了一個加面的機會,拿到了人人special offer,待遇非常給力。
人人的一面面試官非常nice,我當時遲到了30分鐘,由於沒吃飯因此直接蹭了幾個麵包,一邊吃一邊回答問題一邊寫程式碼。由於一面主要考察紙上程式碼,這個是我的強項,因此很輕鬆的通過了。二面相對雜一些,資料結構,演算法,設計模式,多執行緒等都有涉及,不過問的都不深,也比較容易。
終面第一面由自我介紹+讀過的書+寫一段程式碼組成,正好剛剛讀過Sicence of programming,於是就海侃了一頓程式正確性證明的東西,並用這個證明了下自己的程式碼的正確性,目測效果還不錯。
終面第二面是一個大manager面試,這一輪主要是自己的職業發展路線等其它非技術問題,聊的也比較順利,然後他直接告訴我我拿到了special offer。

人民搜尋(2輪面試+1輪終面)
人民搜尋的應屆生面試由1輪演算法面+1輪設計面+1輪終面組成,每一輪面試都是45分鐘,時間控制很嚴。
和其它公司的面試不同,人搜的演算法面試沒有自我介紹環節,直接就是搞演算法題目,至少要做兩道(難度一般,肯定會有一道動態規劃),並在紙上寫出完整的程式碼。由於缺乏溝通,這輪面試略感生硬,不過還是比較順利的通過了。

設計面試多了一些溝通環節,接下來大部分時間會討論一個系統的設計,你需要給出這個系統的架構,接下來面試官會不斷的追問如何改進該系統以應對大使用者量大資料量等極端情況。我這方面的知識不多,只會很土鱉的hash+cache,磕磕絆絆的把這輪過去了。

終面面試官是一個前google工程師,正巧當時我在google面了好幾輪,比較瞭解google面試的套路,因此很順利的就通過了。
總之,人民搜尋的待遇比較給力,而且能搞定戶口,如果想在北京長待而且視戶口很重,那麼人搜值得一試。

8、外企
國外的IT公司一共去了4家,拿到3個offer,面試16場。

微軟(2輪面試+1輪終面)
微軟從去年開始大規模擴招,印象裡以前應屆生招幾十人,現在一個STC(網際網路工程院)就能招二百餘人,因此面試難度也有所下降,面試輪數由以前的5輪左右下降到現在的3輪左右。

這裡多提一句,很多人把微軟和MSRA(微軟亞洲研究院)劃等號,甚至有人認為進了微軟就等於進了MSRA,其實微軟有很多部門,包括STC、STB、MOD等部門,MSRA只是其中一個研究性質很濃的部門。不過MSRA要求極高,和其它部門不同,一般MSRA的FTE只招博士,很少招碩士,招聘需要進行七輪甚至以上的嚴格面試,難度絲毫不亞於谷歌。而MSRA的實習生則容易很多,名校學生一般有內部推薦就可以搞定。

我之前在微軟進行過實習,因此直接參加了實習生轉正面試,三輪面試分別由SDET,SDE和一名高階部門經理進行面試,面試的流程可以參考我之前提到的常規面試流程。與國內IT公司不同,微軟不會問語言細節或是OS細節之類的人品問題(就是那種上網搜一下就明白的題目,C++的虛擬函式實現機制是此類非常典型的人品題),而會集中在演算法設計和程式設計上,其中應屆生面試又以紙上程式碼最為嚴格,即使到了終面依然會有紙上程式碼編寫環節,儘管不會考察特別複雜的演算法,但對細節要求的非常嚴格。好在我之前有微軟幾位SDE的指導,紙上程式碼功夫還是不錯的,並且實習期間獲得了不錯的review,因此比較順利的通過了微軟實習轉正面試。

微策略(2輪面試)
微策略是一家進入中國沒多久的外企,規模不大,工作內容主要是大資料分析+資料視覺化,面試一般由四輪到六輪面試組成。我比較悲催的直接掛在第二輪面試。
微策略是我面試的外企中唯一全程使用英語面試的公司,面試官給人的感覺是很smart,但不nice,具體原因我後面說。

第一輪面試主要問了些面向物件相關的內容,接下來是一些智力題目,我有一道題目(高樓扔雞蛋)沒有說清楚,儘管答案是正確的,但我的推導思路比較繁瑣,因此浪費了大量的時間和麵試官進行溝通。事後回想下面試官還是很nice的,主要還是自己平時想問題淺嘗輒止,才會敗在這道題上。

第二輪面試就讓我感到不爽了,我在自我介紹時直接被面試官打斷,以至於自己的亮點經歷說都說不出來,而且在後續的程式設計環節中,面試官拒絕和我進行交流,我寫完了題目他又說這個和他要求的不太一樣,當時我心裡就開始暗罵wtf了。估計是前一輪被評為weak hire以至於這一輪的面試就是走走形式吧。

雅虎(3輪面試+1輪終面)
雅虎的面試分為3輪技術面和1輪終面,在同一天完成。儘管雅虎公司一直給我一種搖搖欲墜的感覺(經常有傳言雅虎可能會被收購),但雅虎公司的員工給我感覺都很nice且很smart,而且比微軟的員工要有活力許多。

三輪技術面試有兩輪是典型的技術面,自我介紹+技術提問,由於我在簡歷上提到“閱讀了120本以上的計算機經典書籍”,因此被問到了“看過最經典的計算機書”這樣的問題,我拿Brian Kernighan和Rob Pike的The practice of programming吹了一陣,演算法題目相對微軟要難一些,除了動態規劃,也涉及到了字尾陣列等不太常見的資料結構,還好之前有所準備,所以回答的還不錯。

終面的面試官是一名移動部門的老大,問了一些資料結構設計和職業規劃的問題,並用英文進行了一小段交流,由於這些問題準備的很充分,因此跟他聊的比較high,終面也很順利的通過了。

Google(7輪面試)
Google的面試輪數不定,如果表現良好,4輪面試就可以拿到offer,但如果有某輪面試表現一般,可能會進行加面來進行確認面試者是否合格,拿我自己來說,進行了7輪面試(據說有進行到10輪以上的,不過無法確認可信性)。Google是典型的工程師文化工程師面試,沒有終面這個說法,每個面試官都有一票否決權,加上每個面試官考察的點都不一樣,因此Google面試是我經歷過的難度最高的面試。

其實Google的面試我本來沒抱多大希望,因為Google一直給我可望不可及的感覺,因此面試時也很放鬆,這種“自暴自棄”的心態反而讓我發揮的不錯,一步一步走到最後,並拿到offer。

Google的面試每一輪大約45分鐘,時間卡的比較嚴格。面試題目肯定會包含演算法和程式設計(一般體現為紙上程式碼),同時包含其它各種各樣的問題,我經歷了策略題(設計一種策略從而在某個遊戲中達到優勝)、資料結構設計、系統設計、白盒/黑盒測試、專案介紹等五花八門的題目,題目的型別視面試官的型別而定:學術型的面試官(比如說名校PHD)問的題目偏重演算法,工程型的面試官(大多是社招的Googler)問的題目偏重專案經歷。面試題目並不像網上傳說的那麼困難,但是面試官會丟擲很多Probing question,讓你給出一個optimal solution,這著實讓我拙計了幾次,不過即便一時間想不到最優解也不要緊,一邊保持和麵試官的交流一邊試探各種可能的思路,這裡再次推薦下Polya的How to solve it。

由於面試輪數很多,因此這裡就不依次說每輪面試的細節,可以參考下面的Google面試經歷連結。
http://blog.yxwang.me/2012/12/job-hunting-in-usa-1/


《面試體驗:Google 篇》

9、總結

筆試難度:微策略>人搜>人人>雅虎>搜狗>創新工場>騰訊

面試難度:Google>雅虎>人搜>微策略>微軟>人人>百度>騰訊=搜狗=創新工場

待遇:Google>人人>人搜>雅虎>微軟>百度>創新工場旗下子公司

毫不猶豫的選擇了Google,儘管我自己是.Net流,天天折騰VS和C#,linux和unix啥的都沒碰過,但就前景來看,不得不承認Google比微軟強太多了。

老實說我自己進Google感覺像做夢,畢竟不是搞ACM的,大學成績一般,什麼獎學金都沒拿過。

 
但回想一下,這也不全是靠運氣:從07年(那時我大三,一行程式碼沒寫過)掛科開始,決心開始搞計算機這行,編寫自己的第一行靠譜程式碼,獨立完成第一個程式設計作業,閱讀書籍,不懂的就來D版詢問各路大神(這裡謝過FloridDong,UGLee等大神),然後一邊實習一邊讀書學習,花了半年考研考到帝都,在考研結束的那段時間(四個月假期)精讀了資料結構,計算機組成等基礎經典書籍,補習自己的基礎。到帝都之後,在一場即興技術口譯之後,獲得去微軟實習的機會,然後在實習中學習編譯器知識,創作了自己的程式語言和編譯器,加入朋友的創業團隊併合作完成了AppStore TOP1的應用,離開團隊獨立搞定Windows Phone 7上最火的撥號應用、閱讀應用和AV應用並在移動網際網路中賺到自己的第一桶金,通宵一週完成畢業小論文發表並推薦到核心期刊,為了求職寫了三本紙上程式碼,閱讀the Science of programming學會如何證明自己程式碼的正確性,100%的簡歷通過率+100%的筆試通過率,最後進入Google。