相關閱讀 |
>>> 技術話題—商業文明的嶄新時代 >>> | 簡體 傳統 |
英文原文:Competitive Programming: How is competitive programming different from real-life programming?
你在叢林里,有一把小刀,有人要求你去殺掉一只美洲獅。任何人都會問“美洲獅在叢林里到底在做什么?!”,除了程序員。不過,這不是你被訓練為程序員要去做的事情。你在這里要解決問題,而不是對問題提出質疑。
數年的訓練已經教會你了很多,你用小刀削尖木棍,砍斷藤條來甩動一端的尖銳石頭。或許你來自于一流大學,你已經學會了從周圍植物和昆蟲體內榨取必要成分,以增加武器的毒性。
你堅信,你有一種殺掉獅子的、有效的、有能力的方法,你開始為了完成任務而努力。或許你的木棍太短,或者你的毒液不起作用。沒關系,你能夠活著改善方法,并在明天再次試驗。
隨后有人找到了一種方法,收集叢林里的化學東西制作了輕度爆炸物。你的精加工梭鏢的方法對于完成任務,遠遠不是最好的方法了。然而,它仍然是簡單的方法,并繼續在學校里教。每個獵獅人都要被教會如何從頭建造他的工具。
這是“現實中”的編程。
在競爭編程中,你從同樣的資源(小刀)開始,期望你用兩分鐘殺死獅子。
作為初學者,你會盯著獅子,什么也沒做。
很快,你就明白,如果你殺了一只松鼠,說不定裁判認為它是獅子,就這么干吧。
一名更有經驗的程序員,只是堅持刺獅子,希望獅子及時死掉。很快,你知道獅子身上有一些破壞免疫的固定部位,你知道甚至刺這些部位根本不用費力。有時候,獅子沒有暴露這些部位,因此你真正擅長的是殺死松鼠。
那么,為了成為偉大的、有競爭力的程序員,你需要能夠做兩件事。
首先,你必須學會如何找到獅子的致命弱點并一擊斃命。
其次,你必須學會如何讓你的小刀更方便,你要在一分鐘內做一個尖木棍,用剩下的一分鐘把獅子刺死。
但是,你從來沒有足夠時間去制作炸藥來對付獅子。
————
Balajiganapathi Senthilnathan 的觀點
它們就像和 Python 和 Brainfuck 語言【注1】的不同。
在競爭編程中,你不得不選擇首先想到的、你認為可行的算法進行編碼。編程的目標只是搞定它,并最少出錯。你不必担心維護文檔等等。沒必要考慮如何命名變量、切割代碼為函數等等。還有,競爭編程是短暫的,你將不必在一個問題上花上幾天時間。你大部分時間是在編碼。
雖然,競爭編程讓你對算法以及如何實現有了重要的理解,你在大部分工作中將發現,程序員只是在使用算法方面的類庫。因此,競爭編程最有用的地方就是,對于手頭的問題,使用哪種算法。在工作場所,你花在寫代碼的時間只有很少一塊,大部分時間花在了決定去編碼、測試、文檔和……
注1:Brainfuck,是一種極小化的計算機語言,它是由 Urban Müller 在 1993 年創建的。由于 fuck 在英語中是臟話,這種語言有時被稱為 brainf*ck 或 brainf***,甚至被簡稱為 BF。http://zh.wikipedia.org/wiki/Brainfuck
www.labazhou.net 2015-05-19 00:36:30
稱謂:
内容: