Re: [討論] 軟體工作真的有需要刷題嗎?

作者: BBSealion (海獅)   2021-08-15 19:26:07
小弟在後端與資料領域打滾過幾年,也刷過上百題 Leetcode
同意大部分演算法題確實工作上不會用到,但仍然有很多潛在價值存在
就來分享一下我覺得刷題真的"有意義"的那部分好了
1. 工程基本功
例如天字第一題,Two Sum,考得就是一個 Hash Table 的基本概念
也是非常常見的 junior developer 會遇到的場景
例如現在有兩台機器,定期產出 1e6 筆資料量級的 excel 報表
現在要你寫個系統 on-demand 讀取並合併兩張報表後返回給客戶
如果做成 O(N^2) 然後跟主管說他就這麼慢沒辦法
那技術顯然很有問題...
2. 將理論實際應用的能力
例如 Trie 的概念本身不難
但突然碰到沒見過得複雜變化問題
你有辦法馬上反應過來應用上去嗎?
3. Coding 速度與準確度
你有沒有辦法在很短時間,實作一個中等難度的問題,然後一次就 bug free pass
這對應的是你平日工作的開發效率,還有邏輯是否縝密
如果你寫兩三行 code 就要一直 print 看輸出修改邏輯漏洞
代表你對程式操作變數的熟練度不足
當要大量開發一些不太困難的工項時(這是公司常見場景),效率會較低落
而且可能會有潛藏的 bug
甚至 unit test 也幫不了你,因為你根本就沒想到要測試這些 corner case
4. 後端系統設計
要你做資料庫選擇,那最少該對 B+Tree, LSM Tree 等結構有概念
要你做地圖系統,那 Quad-Tree, R-Tree, KD-Tree, Z-Order Indexing 也該能聊聊?
或 Cache 系統最常見的 LRU/LFU cache 選擇
分散式系統最基本的 Consistent Hashing 有哪些應用,好壞是什麼
這類演算法可能實作很複雜導致 Leetcode 不愛考
但 Leetcode 的部分題目也是從這些概念中提煉出來(例如一堆基本 Tree 操作)
足夠小到可以變成一個 10~20min 寫的完的題目
假如你 Leetcode 都寫的出來,想來要理解系統設計真實應用的演算法也不會太困難
5. 靈活思考
這就一些奇怪的觀察力考驗題
看你能不能看穿他轉幾個彎之後,就是某個簡單的演算法概念
跟考益智問題的意思差不多
因為他想找真的很聰明、頭腦很靈活的人
如果聰明人想得出來,大量努力刷題苦練過的普通人也想的出來
那起碼這個篩法有一定機率找到我想要的人,另一些也是肯努力的人
這樣對面試官來說也不錯了
6. 溝通能力
這個應該也被講爛了
很多公司也沒有要你一秒給最佳解(真的題題秒解還會懷疑你是哪邊去偷到題目)
而是要看你一路跟面試官怎樣討論溝通,將答案一步步優化到最佳的整個過程
你刷的題目足夠,思考也會更穩定,討論更聚焦更有方向,對答案更有自信
如果他覺得你是個一起討論研究問題很舒服的人,就有機會給正面評價
我自己就曾在 Appier 面試被丟了一個沒有優於 O(N^2) 還是 O(N^3) 解的問題
(細節部分記憶模糊了... 也可能是沒有 linear time 解)
但他問的一副有的樣子,一直要我再想想
我想了一陣子,還是跟他解釋了幾種不同思路、假設、還有分別會遇到的障礙
然後很有自信的跟他說這確實沒辦法
面試官就很滿意了,說那是他們真實遇到的難題,也確實還找不到辦法,所以跟我聊聊
後來我們又聊了很多有趣的問題,是很棒的面試經驗
假如當時我不夠熟練的話,一定只會一直擔心我哪裡沒想到,做不出來完蛋了死定了
大概就不會有後續了
當然啦,如果碰到不合格的面試官,或考題亂挑一通,那以上情境都不會發生
有些面試官只會背題,甚至自己也不懂
手上有一份答案,你講的跟答案一樣就 pass
你講不一樣但同樣可以過(甚至還更好)的答案,通通都算 fail
那遇到這種也只能說運氣不好,這場考試毫無意義
但不代表這整個演算法面試的模式沒有可取之處。
作者: asd123159 (小傑)   2021-08-15 19:38:00
作者: liang30678 (QQQQ)   2021-08-15 19:43:00
作者: BlacksPig (Black Handsome s Pig)   2021-08-15 19:44:00
作者: aassdd926 (打東東)   2021-08-15 20:47:00
推好文
作者: devilkool (對貓毛過敏的貓控)   2021-08-15 20:47:00
同意
作者: imreader (imreader)   2021-08-15 21:27:00
開發需要這些演算法就會去研究,但跟是否要在面試考是兩回事 。不過對應不同的場景,可以使用何種演算法倒是不錯的考法但直接考那些 Pseudo Code,沒什麼意義知道用什麼來解,對工程師來講就是後續製作的小細節
作者: Lushen (wind joker!!!)   2021-08-15 21:29:00
就資方成本最低的面試的方法 可以吹成這樣也不簡單
作者: imreader (imreader)   2021-08-15 21:30:00
那些網路查就有死背那些 Pseudo Code 沒什麼意義讓這些有興趣的新手們,多貢獻程式到 github 吧
作者: sunsamy   2021-08-15 21:40:00
不就是資方沒能力鑑別人才,才用這樣的方式方便省事,也能
作者: vi000246 (Vi)   2021-08-15 21:40:00
我連two sum是啥都不知道 我好廢
作者: sunsamy   2021-08-15 21:41:00
吹成這樣也不簡單了,考oral language你一定上但是真的人才是不會浪費時間去搞刷題的,賺錢都來不及了
作者: jasonwung (路人JJ)   2021-08-15 21:47:00
作者: WaterLengend (Leeeeeeeeooooooo)   2021-08-15 21:59:00
作者: Lushen (wind joker!!!)   2021-08-15 21:59:00
酸的大概菜雞吧 真的有在面試的就知道以前都要研讀候選人的履歷針對性問一些問題刷題就面前上去leetcode挑個題目 看一下各種解答就跟聯考一樣 大家都標準一致要一個一個去理解每個高中生的特質成本低呢還是同一份考卷給大家寫成本低 挑出成績高的容易呢還是大家都寫同一份考卷 挑出成績高的容易呢
作者: taipoo (要成功要積極)   2021-08-15 22:07:00
推好文
作者: viper9709 (阿達)   2021-08-15 22:24:00
這篇也太強XD
作者: shiauji (消極)   2021-08-15 22:51:00
作者: rdjs (太神啦)   2021-08-15 22:54:00
大家有空就多刷題
作者: herrowui (帝虎改)   2021-08-15 23:08:00
考試在業界一直都是最簡單的做法,只是有些特質考試考不出來就是。
作者: TAMSHUI (讓我醉死在夢裡~)   2021-08-15 23:58:00
刷起來!
作者: yougigun   2021-08-16 00:01:00
同意這篇
作者: qazxws (QAZ)   2021-08-16 00:24:00
不過台灣很多公司考刷題 薪水也不怎麼樣就是了
作者: smily134 (father134)   2021-08-16 00:56:00
作者: askaleroux (FalconTW)   2021-08-16 01:00:00
大聯盟的面試 中華職棒的薪水
作者: wawi2 (@@)   2021-08-16 01:34:00
這篇正解 從面試官的角度來看 就是這麼一回事
作者: umum29 (....)   2021-08-16 01:59:00
台廠很多只是學樣子 考官還不准你和他討論答案
作者: NCUking (中大王)   2021-08-16 02:05:00
有的還直接開leetcode讓你自己寫 笑死
作者: wawi2 (@@)   2021-08-16 02:14:00
台廠考leetcode 就跟我文章說那些公司問腦筋急轉彎依樣
作者: inte629l   2021-08-16 06:49:00
作者: peter9s3b   2021-08-16 10:45:00
面試考一堆,薪水也要跟上啊
作者: Gjero   2021-08-16 10:52:00
作者: Mtcat (山地貓)   2021-08-16 11:26:00
11
作者: yiche (你若安好,便是晴天)   2021-08-16 11:54:00
推推 謝謝分享
作者: A4P8T6X9 (殘廢的名偵探)   2021-08-16 13:59:00
作者: leicheong (睡魔)   2021-08-16 16:47:00
但我想說實際工作的場合m需要一直看output修正結果的場合意外地多呢. 因為很多時候用戶最初給的公式和預期的結果會有出入. (有時是基於前一個系統的bug)因為已交上去的報表不能改, 所以如何有效率的能datamap到用戶要求的結果在實際操作也同樣重要. 甚至關係到專案能不能結尾.
作者: ppc ( )   2021-08-16 17:21:00
有道理
作者: javatea (齁齁)   2021-08-16 18:48:00
公司沒時間好好挑人也能被你神話成這樣 你馬好~ lol
作者: silence0925 (小文青)   2021-08-16 19:54:00
誰兩三行會印一次阿 但十行二十行檢查一次不好嗎?
作者: sooge (老衲)   2021-08-16 20:10:00
高手一定都是寫完一個project 才print一次
作者: wulouise (在線上!=在電腦前)   2021-08-16 21:44:00
unit test cases 寫完還需要print?
作者: chuegou (chuegou)   2021-08-16 23:54:00
3現在是我的痛點 明知道有錯還是想讓編譯器幫我檢查
作者: silence0925 (小文青)   2021-08-17 00:14:00
寫unit test 跟自己在寫的時候先確認 不衝突吧?寫完一個project 才print一次 是反串????
作者: zebraseven (Die walkuere)   2021-08-17 01:15:00
作者: ukuk666888 (逆戰)   2021-08-17 17:20:00
推好文
作者: s0914714 (YA)   2021-08-19 14:32:00
刷題的重點不是在記解法吧 如果認真思考收穫其實不少討論區的神人都能想到令人嘆為觀止的答案但可惜的是大部分人只為了求職硬記解法
作者: chia3120 (棉被蟲小柔)   2021-08-21 11:17:00
作者: paulshain04 (paulshain04)   2021-09-13 06:55:00
推 好文分享

Links booklink

Contact Us: admin [ a t ] ucptt.com