每日最新頭條.有趣資訊

神回答:編程到底難在哪裡?

【回復“1024”,送你一個特別推送】

今天在瀏覽知乎的時候,看到了一個問題:編程到底難在哪裡?看到一個非常有意思的回答,這個回答雖然並沒有說到編程到底難在哪裡的本質,但是卻清清楚楚說明了程式員在編程的時候的思維邏輯和思考的整個過程。這個回答簡直是通俗易懂,非常形象的表述了程式員在編程時需要考慮的複雜邏輯。

這個回答可以非常科普的告訴程式員身邊的朋友,程式員在編程的時候都是如何思考和進行業務邏輯編程處理的。

下面高能回答來了,可以轉到朋友圈給你們的朋友科普一下,程式員編程的時候,思維邏輯到底有多複雜!!!

普通人:我今天要買一斤蘋果。

程式員:

我今天要買一斤蘋果。

因為我隻喜歡紅富士蘋果,所以我隻買紅富士蘋果。

我能接受的最高價格是 10 元 / 斤。

正常情況下一斤蘋果用一個袋子能裝下,但是為防萬一,我會帶兩個袋子。

我知道附近的 3 家水果店,所以我會依次訪問這 3 家水果店。

根據上述條件,我設計出以下的買蘋果的流程:

這個流程怎麽樣?我來設計一些測試樣例,測試一下這個流程。

測試發現一個問題:如果水果店 0 和水果店 1 都有紅富士蘋果並且價格都低於 10 元 / 斤,而且水果店 1 的價格比水果店 0 更低,那麽我希望買水果店 1 的蘋果,但我設計的流程會讓我買水果店 0 的蘋果。

為了解決這個問題,我應該先詢問所有水果店的價格,然後去價格最低的那一家買蘋果。

經過修改,我重新設計出以下的買蘋果的流程:

現在這個流程是不是完美了呢?不是,我還能發現很多問題。

如果 3 家水果店都有紅富士蘋果但都不到一斤,但是三家店加起來能達到一斤,那麽我不應該結束流程回家,而是應該把三家店的紅富士蘋果都買下來。

如果我向水果店詢問價格的時候這家店還有紅富士蘋果,但我詢問完所有水果店的價格後這家店的紅富士蘋果賣完了,那麽我的流程會讓我試圖處理不存在的紅富士蘋果。

我走路的過程中可能會遇到突發事件,比如發現了新的水果店,比如袋子破掉了蘋果掉一地,對於這些情況我的流程都無法進行處理。

啊問題太多了我懶得再改流程了。我還是去 X 寶買吧。那麽接下來我要設計一個在 X 寶買紅富士蘋果的流程……

文/DJ Hitori(文章轉載自知乎網友 DJ Hitori 的回答)

獲得更多的PTT最新消息
按讚加入粉絲團