答疑 | 算法崗和開發(fā)崗哪個前景更好?
↓↓↓點擊關注,回復資料,10個G的驚喜
本文約4100字,建議閱讀10+分鐘
算法崗和開發(fā)崗哪個前景更好?
開發(fā)崗需要做的是根據(jù)具體需求來搭建/維護對應的線上模塊,寫代碼實現(xiàn)線上邏輯。具體而言,開發(fā)崗更像純粹的“工程師”,需要根據(jù)需求來進行功能開發(fā)、測試、代碼上線,比如在召回等某個模塊修改個代碼邏輯以推進某個業(yè)務上線。由于每項工作都是目標確定,工作量也是可以直觀衡量的,所以工作確定性很強,產(chǎn)出也比較確定。一旦需求比較多時,就會堆時間加班解決,而加班多工作量肯定會更多,成績一般也更突出。所以,開發(fā)崗更多是“身體累”。 算法崗的目標主要是通過各種手段提升對應指標,比如推薦系統(tǒng)的點擊率、轉化率、用戶停留時長等。舉上面例子來說,是通過優(yōu)化召回、粗排、精排等策略/模型結構,優(yōu)化模型訓練數(shù)據(jù),對接新業(yè)務優(yōu)化業(yè)務指標等各種不同方式來提升指標。到了現(xiàn)在算法已經(jīng)接近瓶頸時,算法會過得非常難受,每個優(yōu)化點不一定會有用(大多是無效的),需要反復提出新方案、優(yōu)化、排查指標、再提出新方案不斷循環(huán)直到拿到某個收益點。有時改幾行代碼結果帶來收益,有時又投入巨大工作量也沒收益,所以,這方面工作量和工作目標上更不好量化,算法崗更多是“心累”。
算法需要熟悉各類機器學習/深度學習算法知識、各類策略、比較前沿的新算法/模型,除此之外,現(xiàn)在對算法的工程能力要求也是越來越高,基本的架構(比如上面說的公司內部推薦/廣告算法各個模塊的代碼)、架構開發(fā)基礎(C++,Java等)、數(shù)據(jù)開發(fā)(spark等、flink)。主要原因一方面是簡單的模型優(yōu)化已經(jīng)很難拿到收益了,新開發(fā)的算法逐漸更復雜,想要讓模型更合乎預期就需要對架構很熟悉方便模型設計、指標排查、提出新方案等,另一方面,也是為了快速迭代,開發(fā)同學需求太多做不完的時候,算法崗不可能干等著別人開發(fā),自己動手完成一部分簡單開發(fā)能夠保證工作正常推進。 開發(fā)崗則需要對架構知識、開發(fā)基礎等各種知識比算法同學更深入,具體哪部分技術重要取決于具體的開發(fā)崗位。
由于前幾年ai太火,各個專業(yè)都往“算法”上轉,當年削尖腦袋進算法各方向的學生這兩年也開始批量畢業(yè)。因此,顯而易見的是算法崗面試會更內卷一些,尤其是cv、nlp等偏研究性質且落地場景不多的算法崗位。目前推薦/廣告算法還不算卷,主要原因是沒有平臺導致很少學校會專門研究這兩個方向。面試上主要還是看以往的算法項目經(jīng)驗及對算法本身的理解、算法基礎知識、刷題等。 開發(fā)崗種類比較多,比如后端、前端等,而且根據(jù)不同業(yè)務可能又會使用不同的技術棧(比如一些用C++,另一些用go等)。開發(fā)崗是硬需求,每個公司都需要且數(shù)量不少,所以內卷程度會比算法輕。面試上,也都大同小異,主要也是問過往項目,基礎知識(對應開發(fā)方向的)以及刷題。
https://www.zhihu.com/question/490150407/answer/2173649548
https://www.zhihu.com/question/490150407/answer/2158935592
https://www.zhihu.com/question/490150407/answer/2164598780
https://www.zhihu.com/question/490150407/answer/2166902713
推薦閱讀
用Python學線性代數(shù):自動擬合數(shù)據(jù)分布 Python 用一行代碼搞事情,機器學習通吃 Github 上最大的開源算法庫,還能學機器學習! JupyterLab 這插件太強了,Excel靈魂附體 終于把 jupyter notebook 玩明白了 一個超好用的 Python 標準庫,666? 幾百本編程中文書籍(含Python)持續(xù)更新 100天搞定機器學習|Day63 徹底掌握 LightGBM
好文點個在看吧!
評論
圖片
表情
