伯樂線上注:本文還是來自譯者 Wilson Wen 的郵件投稿。如果其他朋友也有不錯的原創或譯文,可以嘗試推薦給我們。以下是譯文。
—————————–
自從發表了《堅持程式設計:如何找到一份工程師工作》這篇文章,很多人問我在沒有學位的情況下怎麼獲得在谷歌(Google)工作的機會。你通向成功之路或許會和我不一樣,下面是我的故事。
我非常希望能上大學,我的理想大學是加利福尼亞大學洛杉磯分校(UCLA)。很不幸,我高中的 GPA 低的令人尷尬,只有2.45。所以實際上,我並沒有隨便選擇一家大學。我在普渡大學蓋萊默分校上的電腦科學課程,希望可以當交換生或者找到別的出路。差不多兩個學期以後,後者發生了。我收到了一個不可拒絕的offer。
第一步:在你能做之前先裝裝樣子。大學的時候,我在一家專門為本地企業建設網站小公司工作,時薪是12美金。在我的職業規劃裡,我從未想過做這樣一份工作,但當時來看還不錯。
我同時參與多個專案,身負重任,我選擇埋頭苦幹,全力以赴。從這個過程中我獲得了很多信任。同時,我嘗試利用我不多的業餘時間開發遊戲。我去到一個 天主教會,向那裡的管理人員請求提供我少量的錢和三個月時間來開發這個遊戲,然後在網上銷售。我繪製了漂亮的報表和顏色豐富的圖片,向他們展示共享軟體模型( shareware model )是怎麼工作以及如何確切知道這會帶來回報。實際上,我對於我將要做的東西還不是非常清楚,但是他們買了,也許是由於那些漂亮的顏色。
經過兩個月的開發,我將Demo釋出到網上。一個在加州剛剛起步的創業公司CodeFire發現我的Demo和他們的遊戲如此相似,都是一個從上往 下看的太空射擊遊戲,都和SubSpace非常相似,除了3D部分。不幸的是,他們通過勒令停止通知函與我交涉。我只能給他們一個回覆“當然可以,只要你們聘請我工作,我就馬上停止”。他們馬上給我發了offer。然後我就收拾行裝去了加州。
第二步:和大師交朋友。這可能是最重要的事情。在你的領域裡找到一位大師,讓他們成為你的導師,不停的向他們學習。當我在Double Helix工作時,有一位大師叫 Nathan Hunt,他是我遇過最聰明的卻又最謙卑的人。不管我問的問題如何的基礎,他都極度耐心的一一解答。我至少上千次的走進他辦公室,問一些諸如“我怎樣才能平滑的將一個旋轉矩陣插值到另外一個裡面”,“我應該如何實現移動柱體的碰撞檢測”的問題。幾年以後,他晚我一個月加入了谷歌。
每一個導師都改變了我解決問題或者看待世界的方法,而這隻有其中的一小部分。
第三步:填補不足。因為我沒有一個正式的計算機學位,我清楚自己缺乏很多基礎的理論知識。比如,我實現了一個物理引擎,但從未解決過動態規劃的問題。為了填補這些空缺,我幾乎實現了所有我見過或讀過的資料結構與演算法。這些雖然都已經有了,但是通過觀察而知道其如何 工作,與通過實現而知道其為什麼可行有著巨大差別。
完成以下幾點:
- 至少掌握其中一門語言: C、 C++、Objective-C、Java、PHP、Python 或 Ruby。瞭解至少一門其他語言,熟悉Scala、Haskell 或者 Lisp。
- 學習資料結構。嘗試實現其中的大部分。理解他們的時間複雜度。
- 解決程式設計問題。閱讀下面的文章( Read this)和解決這裡的大多數問題( solve many of these)。
- 為你的專案建立主頁。(比如,程式設計框架、移動應用、網頁應用、小遊戲等)
第四步:找到自信。在離開印第安納州6年以後,我已經通過多個平臺釋出了超過6個遊戲。我漸漸覺得無聊,需要新的挑戰。我申請了谷歌的職位,由於我沒有學位,我想著如果我被聘請了,我就能成為夢寐已久的一名真正的工程師了。但是,我從未收到回信,對於這一點我感到一點都不意外。
一年以後,我再次提交了我的簡歷。而這一次,我把“教育”這一部分刪除了。諷刺的是,這次一位招聘官給我打電話和我預約了一個電話技術面試。我諮詢是否可以預約在兩個星期以後,他同意了。我需要這一部分時間。我利用這段時間,盡最大努力將盡可能多的演算法和資料結構塞到我的腦子裡。我每天編碼 12-14個小時,解決了幾百道程式設計題。我慢慢沉迷進去了,直到我對谷歌面試的害怕變成了自信和興奮。
我記得住在谷歌的每一次面試,每一次與他們的交鋒。面試官都很健談,我相信他們都看得出來我非常興奮的迎接他們的問題。
我遇到的一些面試題如下:
- 給定一組2維點,計算出他們的輪廓線。這非常簡單,我採用了非常一種通用的資料結構叫做最大堆。這道題有很多解決方法,這裡有一個非常好的。( good one)
- 設計微軟的畫筆。這是目前為止最有趣的問題。我從畫介面和類圖開始,我提到了畫筆桶(Paint Bucket),面試官讓我實現它。幸運的是,多虧TopCoder,我閉著眼睛都知道如何實現一個迭代的,廣度優先遍歷的桶。
- 描述你的軟體的長處。這是一道開放的討論面試題。我說到了測試的型別和他們的重要性(單元測試,整合測試,驗收測試)。我又說到了程式碼風格的一致性和可維護性等等。這些東西你可以在《程式碼大全》和 《Effective Java》找到。
我真正的享受每一輪面試和每一個扔給我的問題。如果我沒有那樣認真的準備,我現在肯定不是這個樣子。面試完了以後,我感覺非常好。但是,我聽說即使招聘委員組同意了給offer,拉里本人仍有權利否決。我擔心一旦他看到我沒有學位以後,我就完蛋了。
不過,這並沒有發生,有一天我在Santa Clara吃著壽司午餐,我接到了電話,我非常熱情的接受了Offer。那一天,我清楚的知道我不用再回到學校裡去了。
勝利的戰士先勝了再去戰場,而失敗的戰士先上戰場再去求勝。
喜歡或者討厭這篇文章,都請讓我知道。@guitardave24
經過5年學習和成長,我現在已經不再為谷歌幹活了。