0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

GitHub上最勵志的計算機自學(xué):John Washam

算法與數(shù)據(jù)結(jié)構(gòu) ? 來源:算法與數(shù)據(jù)結(jié)構(gòu) ? 作者:算法與數(shù)據(jù)結(jié)構(gòu) ? 2020-10-10 16:58 ? 次閱讀

John Washam勵志要成為一名谷歌軟件工程師,但沒有CS專業(yè)背景的他,只能通過自己的努力來達(dá)成理想。

于是,8個月的時間里,小哥花了數(shù)千小時閱讀書籍、編寫代碼、觀看CS技術(shù)講座,一路披荊斬棘、打怪升級。

最終,雖然沒有去谷歌,但他人到中年,還順利成為了一名亞馬遜AWS的技術(shù)專家,年薪百萬。

更加難能可貴的是,小哥還將自學(xué)經(jīng)驗編寫成了一份教程,在GitHub上線以來,已收獲近10萬星的好評。

正如他所說:

即便沒有面上(?)夢寐以求的谷歌,但是教程,也可以用來好好充實一下自己。

PS:教程有中文版哦~~

GitHub超10萬星自學(xué)寶典

是什么樣的編程教程,能如此火爆?

小哥最初的目的是“考上”谷歌,于是每天自學(xué)8-12個小時,堅持了8月有余。邊學(xué)還順手整理出了這份自學(xué)項目。

不過在完成這項學(xué)習(xí)計劃后,他最終被亞馬遜錄取,成為一名軟件工程師。

Washam表示:

無論你要面試哪家軟件公司,這里的項目可以讓你做好充分的準(zhǔn)備,包括像亞馬遜、Facebook、谷歌和微軟這樣的科技巨頭。

接下來,我們就跟著Washam的腳步去了解一下這份面試寶典。

選擇語言、必備知識資源

首先要做的就是選擇一門語言,在Google一般是C++、Java、Python,有時也會用到JavaScript、Ruby。背后還有一些如SQL、HTML等技術(shù)沒有列出。

接著開始學(xué)習(xí)計算機硬件知識:

然后補充計算機專業(yè)的基礎(chǔ)數(shù)學(xué)知識,如算法復(fù)雜度 / Big-O / 漸進(jìn)分析法、數(shù)據(jù)結(jié)構(gòu)、樹、排序、圖論。

此外還有遞歸、動態(tài)規(guī)劃、組合與概率、NP&NP-完全和近似算法、緩存、線程與進(jìn)程、系統(tǒng)設(shè)計、可伸縮性、數(shù)據(jù)處理。

看到這么多知識點,你會不會覺得有點懵呢?Washam告訴你一點小技巧。

因為你不可能一遍就記住所有知識點。所以需要把要回顧的知識點做成抽認(rèn)卡(flashcard):正常的及帶有代碼的,類似于背單詞。

每種卡都會有不同的格式設(shè)計。項目主頁中就有抽認(rèn)卡的源代碼,可以根據(jù)自己的學(xué)習(xí)特點去制作。

Washam還留有一組 ASCII 碼表、OSI 堆棧、Big-O 記號及更多的小抄紙,以便在空余的時候可以學(xué)習(xí)。每編程半個小時就要休息一下,并去回顧你的抽認(rèn)卡。

當(dāng)然,論文的閱讀也是必不可少的,尤其是谷歌曾經(jīng)發(fā)表的一些基礎(chǔ)技術(shù)論文。

書籍則推薦一些關(guān)于算法和C++編程之類的。

Google面試注意事項

面試的第一步當(dāng)然是要有一份好的簡歷,這樣才能為你爭取到寶貴的面試機會。知名科技博主Steve Yagge給出了10個貼士,幫你做出一份還不錯的簡歷。

這位Steve曾經(jīng)在亞馬遜、Google都工作過,Washam的這個項目就大量地引用了他的技術(shù)博客內(nèi)容。

在面試時,你可能會遇到這20個問題,每個問題準(zhǔn)備 2-3 種回答。準(zhǔn)備點故事,而不要只是擺一些你完成的事情的數(shù)據(jù)。

面試官在也會問你還有哪些問題,不要說自己沒有什么要問題,可以試試問一些此類問題:

當(dāng)然,進(jìn)入Google也不意味著結(jié)束,你還要新的學(xué)習(xí)過程。

Washam還有一份附加內(nèi)容,包括Emacs和Vim、Unix命令行工具、密碼學(xué)。這些內(nèi)容雖然不會直接用到,但是會大大提高你的效率。

一個Web前端的新征程

其實嚴(yán)格來講,John并不是一個編程小白。

從高中起,John就開始學(xué)習(xí)編程,學(xué)的是BASIC語言,這還在是上世紀(jì)90年代。

大學(xué)畢業(yè)拿到經(jīng)濟(jì)學(xué)學(xué)位后,他先是在軍隊服役兩年,駐扎韓國。

退役后他留在韓國教英語,突然發(fā)現(xiàn)自己離開CS領(lǐng)域的這幾年間,太多的新技術(shù)新工具出現(xiàn),自己的知識結(jié)構(gòu)出現(xiàn)了斷層,無法支撐起一個程序員的職業(yè)生涯了。

于是他利用一切業(yè)余時間,艱苦地學(xué)習(xí)Perl、HTML、CSS(當(dāng)時這還是新東西)、JavaScript和SQL。

終于在2001年,John正式成為了一個網(wǎng)頁開發(fā)程序員,開始了19年的碼農(nóng)生涯。

截止2017年,John的職業(yè)生涯可謂十分成功:在大小公司都有過任職、組建管理過項目團(tuán)隊、經(jīng)營壯大過初創(chuàng)公司,自己還親自創(chuàng)辦了3家軟件公司,其中2家至今還在健康運營。

按照J(rèn)ohn自己的話說,這十幾年的工作經(jīng)歷,將他鍛煉成了一個合格的程序員、一個優(yōu)秀的產(chǎn)品經(jīng)理、一個CEO、一個市場銷售。

但是他的目標(biāo)不止于此。他的夢想是在谷歌任職軟件工程師,在充滿智慧和創(chuàng)造力的團(tuán)隊里提高自己。

最初他認(rèn)為憑自己的工作經(jīng)驗可以輕松獲得職位,但拿到了谷歌面試題他才發(fā)現(xiàn)自己欠缺太多。

一個優(yōu)秀的軟件工程師應(yīng)該精通數(shù)據(jù)結(jié)構(gòu)和算法、匯編語言、內(nèi)存設(shè)計等,還要綜合考慮代碼和程序結(jié)構(gòu)對機器在應(yīng)用場景下的影響。

于是他以這份谷歌試題為指導(dǎo),開始了編程自學(xué)。

并且在github上建立了「9894項目」,因為谷歌建立與1998年9月4日。

后來這個項目改名為現(xiàn)在的「coding interview university」。

CS自學(xué)三點注意事項

John結(jié)合自己的學(xué)習(xí)經(jīng)歷,給出了三點自學(xué)編程的建議。

一、早問早計劃,不要想當(dāng)然

John最大的教訓(xùn)是自己花了太多時間學(xué)習(xí)根本用不上的東西,比如他曾經(jīng)用了3周時間閱讀了1000多頁C++的資料,但是最后面試和工作中用的卻是Python。

△這是John的算法學(xué)習(xí)資料,最后證明走了冤枉路

原因是他擔(dān)心面試時可能會被問到。

這個例子不是說C++沒必要學(xué)。

而是強調(diào)你要提前收集信息做出計劃,在不同的項目上分配合理的學(xué)習(xí)時間,提高效率。切忌「我覺得……」。

二、視頻比看書效率更高

觀看視頻的學(xué)習(xí)效率自然要比自己啃書快。

找到好的教學(xué)視頻,意味著你有更多的時間實際演練編程題目。

三、反復(fù)溫習(xí)十分重要

不斷反復(fù)是形成記憶的關(guān)鍵,正如我們在上文提到的,John推薦使用記憶卡。

他自己制作了1792個電子記憶卡。一有空閑時間就掏出來溫習(xí),比如超市排隊時、公交車上等等。

對于一個卡片的的問題,回答正確還不夠,John會在一段時間內(nèi)多次回答正確才會標(biāo)記為「已掌握」。

最終這位小哥沒有去谷歌,而是接到了亞馬遜的offer,現(xiàn)在他在亞馬遜做軟件工程師。

但是他自己說之前的學(xué)習(xí)經(jīng)歷并不是無用功,現(xiàn)在他已經(jīng)全面掌握了軟件工程的基本技能,無懼工作中的任何挑戰(zhàn),并且實現(xiàn)自我飛躍的那一天越來越近。

而且John小哥的經(jīng)歷,也不局限于程序員本身,多于更多人而言,也有值得參考之處。

他認(rèn)定了一個目標(biāo),然后制定計劃、勤奮付出,最后天道酬勤獲得回報。

John可能也是一個「一萬小時定律」的擁躉,但就算按照他每天12小時、堅持8個月(每月31天),他從一個網(wǎng)站前端到AWS技術(shù)專家,歷時也不過2976小時——遠(yuǎn)未到1萬小時。

但就是這樣目標(biāo)堅定的8個月,John從入門到獲得大廠認(rèn)可,百萬年薪加持。

外媒調(diào)查亞馬遜軟件工程師平均年薪超過百萬人民幣

這是我們在GitHub看到最勵志的故事,也是我們希望讓更多人看到的原因,并且由衷希望更多人因為這樣的經(jīng)歷和分享,創(chuàng)造屬于自己的故事。

坊間笑談太多的“從入門到放棄”,但也有人“從入門到百萬年薪”。

生命不息,奮斗不止,Keep walking~

傳送門:

GitHub項目地址:
https://github.com/jwasham/coding-interview-university

電子記憶卡項目地址:
https://github.com/jwasham/computer-science-flash-cards

參考鏈接

個人博客:
https://www.freecodecamp.org/news/why-i-studied-full-time-for-8-months-for-a-google-interview-cc662ce9bb13/

責(zé)任編輯:xj

原文標(biāo)題:GitHub上最勵志的計算機自學(xué)教程

文章出處:【微信公眾號:算法與數(shù)據(jù)結(jié)構(gòu)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 計算機
    +關(guān)注

    關(guān)注

    19

    文章

    7513

    瀏覽量

    88173
  • CS
    CS
    +關(guān)注

    關(guān)注

    0

    文章

    54

    瀏覽量

    24544
  • GitHub
    +關(guān)注

    關(guān)注

    3

    文章

    472

    瀏覽量

    16475

原文標(biāo)題:GitHub上最勵志的計算機自學(xué)教程

文章出處:【微信號:TheAlgorithm,微信公眾號:算法與數(shù)據(jù)結(jié)構(gòu)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    云端超級計算機使用教程

    云端超級計算機是一種基于云計算的高性能計算服務(wù),它將大量計算資源和存儲資源集中在一起,通過網(wǎng)絡(luò)向用戶提供按需的計算服務(wù)。下面,AI部落小編為
    的頭像 發(fā)表于 12-17 10:19 ?138次閱讀

    工業(yè)中使用哪種計算機?

    在工業(yè)環(huán)境中,工控機被廣泛使用。這些計算機的設(shè)計可承受極端溫度、灰塵和振動等惡劣條件。它們比標(biāo)準(zhǔn)消費類計算機更耐用、更可靠。工業(yè)計算機可控制機器、監(jiān)控流程并實時收集數(shù)據(jù)。其堅固的結(jié)構(gòu)和專業(yè)功能
    的頭像 發(fā)表于 11-29 14:07 ?177次閱讀
    工業(yè)中使用哪種<b class='flag-5'>計算機</b>?

    量子計算機與普通計算機工作原理的區(qū)別

    超越世界最強大的超級計算機,完成以前不可想象的任務(wù)!這意味著量子計算機可能會徹底改變我們的生活。 在本文中,我們將先了解普通計算機的工作原理,再深入探討量子
    的頭像 發(fā)表于 11-24 11:00 ?354次閱讀
    量子<b class='flag-5'>計算機</b>與普通<b class='flag-5'>計算機</b>工作原理的區(qū)別

    工業(yè)計算機類型介紹

    工業(yè)領(lǐng)域沒有計算機的世界就像沒有管弦樂隊的交響樂,缺乏實現(xiàn)最佳性能所需的和諧和精確度。計算機徹底改變了工業(yè)的運作方式,將效率、準(zhǔn)確性和創(chuàng)新推向了新的高度。事實,根據(jù)最近在印度進(jìn)行的一項研究
    的頭像 發(fā)表于 11-04 15:56 ?235次閱讀
    工業(yè)<b class='flag-5'>計算機</b>類型介紹

    計算機接口位于什么之間

    計算機接口是計算機硬件和軟件之間、計算機與外部設(shè)備之間以及計算機各部件之間傳輸數(shù)據(jù)、控制信息和狀態(tài)信息的硬件設(shè)備和軟件程序。它在計算機系統(tǒng)中
    的頭像 發(fā)表于 10-14 14:02 ?442次閱讀

    簡述計算機總線的分類

    計算機總線作為計算機系統(tǒng)中連接各個功能部件的公共通信干線,其結(jié)構(gòu)和分類對于理解計算機硬件系統(tǒng)的工作原理至關(guān)重要。以下是對計算機總線結(jié)構(gòu)和分類的詳細(xì)闡述,內(nèi)容將涵蓋總線的基本概念、內(nèi)部結(jié)
    的頭像 發(fā)表于 08-26 16:23 ?2044次閱讀

    晶體管計算機和電子管計算機有什么區(qū)別

    晶體管計算機和電子管計算機作為計算機發(fā)展史上的兩個重要階段,它們在多個方面存在顯著的區(qū)別。以下是對這兩類計算機在硬件、性能、應(yīng)用以及技術(shù)發(fā)展等方面區(qū)別的詳細(xì)闡述。
    的頭像 發(fā)表于 08-23 15:28 ?1875次閱讀

    工業(yè)控制計算機的特點 工業(yè)控制計算機的應(yīng)用領(lǐng)域

    工業(yè)控制計算機是一種專門為工業(yè)自動化和控制系統(tǒng)設(shè)計的計算機。它具有高度的可靠性、穩(wěn)定性和實時性,能夠滿足工業(yè)生產(chǎn)過程中對控制精度和響應(yīng)速度的嚴(yán)格要求。 工業(yè)控制計算機的特點 高可靠性 :工業(yè)控制
    的頭像 發(fā)表于 06-16 11:30 ?1495次閱讀

    工業(yè)控制計算機與普通個人計算機相比有何區(qū)別?

    引言 隨著科技的不斷發(fā)展,計算機在各個領(lǐng)域的應(yīng)用越來越廣泛。在眾多計算機類型中,工業(yè)控制計算機和普通個人計算機是兩種常見的計算機。盡管它們在
    的頭像 發(fā)表于 06-11 10:45 ?997次閱讀

    工業(yè)計算機與普通計算機的區(qū)別

    在信息化和自動化日益發(fā)展的今天,計算機已經(jīng)成為了我們?nèi)粘I詈凸ぷ髦胁豢苫蛉钡墓ぞ?。然而,?b class='flag-5'>計算機領(lǐng)域中,工業(yè)計算機和普通計算機雖然都具備基本的計算
    的頭像 發(fā)表于 06-06 16:45 ?1462次閱讀

    【量子計算機重構(gòu)未來 | 閱讀體驗】+ 了解量子疊加原理

    作為零基礎(chǔ)初學(xué)級的量子小白,對神秘詭異的量子世界充滿了好奇。說起量子計算機,我有許多問號,量子計算機的工作原理是什么?它和電子計算機有什么區(qū)別?量子計算機如何編程?內(nèi)部結(jié)構(gòu)是怎樣的?量
    發(fā)表于 03-13 17:19

    【量子計算機重構(gòu)未來 | 閱讀體驗】+量子計算機的原理究竟是什么以及有哪些應(yīng)用

    本書內(nèi)容從目錄可以看出本書主要是兩部分內(nèi)容,一部分介紹量子計算機原理,一部分介紹其應(yīng)用。 其實個人也是抱著對這兩個問題的興趣來看的。 究竟什么是量子計算機相信很多讀者都是抱著這個疑問
    發(fā)表于 03-11 12:50

    【量子計算機重構(gòu)未來 | 閱讀體驗】+ 初識量子計算機

    欣喜收到《量子計算機——重構(gòu)未來》一書,感謝電子發(fā)燒友論壇提供了一個讓我了解量子計算機的機會! 自己對電子計算機有點了解,但對量子計算機真是一無所知,只是聽說過量子糾纏、超快的運算速
    發(fā)表于 03-05 17:37

    量子計算機的未來

    了解量子計算機對于工業(yè)生產(chǎn)和產(chǎn)品研發(fā)的使用
    發(fā)表于 02-01 15:30

    微機原理和計算機組成原理的區(qū)別

    微機原理和計算機組成原理是計算機科學(xué)中兩個重要的主題,它們雖然有一定的關(guān)聯(lián),但也存在一些區(qū)別。本文將詳細(xì)闡述微機原理和計算機組成原理的區(qū)別,并從不同的角度對它們進(jìn)行分析比較。 首先,我們從定義的角度
    的頭像 發(fā)表于 01-14 14:56 ?3483次閱讀