編程到底難在哪里罕扎?這回答無敵了聚唐!

普通人:

我今天要買一斤蘋果。

程序員:

我今天要買一斤蘋果腔召。

因為我只喜歡紅富士蘋果杆查,所以我只買紅富士蘋果。

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

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

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

根據(jù)上述條件抡柿,我設(shè)計出以下的買蘋果的流程:

買蘋果流程開始

? ? 對水果店0舔琅、水果店1、水果店2依次執(zhí)行:

? ? 拜訪一家水果店流程開始

? ? ? ? 走到此水果店

? ? ? ? 如果此水果店沒有開門沙绝,則結(jié)束當(dāng)前的“拜訪一家水果店流程”

? ? ? ? 如果此水果店沒有蘋果搏明,則結(jié)束當(dāng)前的“拜訪一家水果店流程”

? ? ? ? 如果此水果店的蘋果當(dāng)中沒有紅富士蘋果鼠锈,則結(jié)束當(dāng)前的“拜訪一家水果店流程”

? ? ? ? 如果此水果店的紅富士蘋果剩余不到一斤闪檬,則結(jié)束當(dāng)前的“拜訪一家水果店流程”

? ? ? ? 如果此水果店的紅富士蘋果的價格高于10元/斤星著,則執(zhí)行3次:

? ? ? ? 講價流程開始

? ? ? ? ? ? 詢問店主是否愿意將價格降到10元/斤或更低

? ? ? ? ? ? 如果店主愿意,則跳過剩余的“講價流程”

? ? ? ? 講價流程結(jié)束

? ? ? ? 如果此水果店的紅富士蘋果的價格仍然高于10元/斤粗悯,則結(jié)束當(dāng)前的“拜訪一家水果店流程”

? ? ? ? 打開一個袋子虚循,將其作為當(dāng)前的袋子

? ? ? ? 重復(fù)執(zhí)行以下流程,直到總重量大于一斤:

? ? ? ? 裝袋一個蘋果流程開始

? ? ? ? ? ? 從所有的不在袋子中的紅富士蘋果中選出最好的一個

? ? ? ? ? ? 如果此蘋果能裝入當(dāng)前的袋子样傍,則將此蘋果裝入當(dāng)前的袋子横缔,否則執(zhí)行:

? ? ? ? ? ? 換袋子流程開始

? ? ? ? ? ? ? ? 如果我有剩余的袋子,則從中任意選出一個并作為當(dāng)前的袋子衫哥,否則執(zhí)行:

? ? ? ? ? ? ? ? 向店主要袋子流程開始

? ? ? ? ? ? ? ? ? ? 向店主索要一個袋子

? ? ? ? ? ? ? ? ? ? 如果店主拒絕給我袋子茎刚,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“拜訪一家水果店流程”

? ? ? ? ? ? ? ? ? ? 將店主給我的袋子作為當(dāng)前的袋子

? ? ? ? ? ? ? ? 向店主要袋子流程結(jié)束

? ? ? ? ? ? 換袋子流程結(jié)束

? ? ? ? ? ? 測量我的所有袋子里的所有蘋果的總重量

? ? ? ? 裝袋一個蘋果流程結(jié)束

? ? ? ? 根據(jù)我的所有袋子里的所有蘋果的總重量和店主給出的價格撤逢,計算我應(yīng)付的價格

? ? ? ? 向店主詢問我應(yīng)付的價格

? ? ? ? 如果我不接受店主索要的價格膛锭,則執(zhí)行3次:

? ? ? ? 校對流程開始

? ? ? ? ? ? 向店主解釋我計算出的價格,并詢問其是否同意

? ? ? ? ? ? 如果店主同意蚊荣,則跳過剩余的“校對流程”

? ? ? ? 校對流程結(jié)束

? ? ? ? 如果我仍然不接受店主索要的價格初狰,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“拜訪一家水果店流程”

? ? ? ? 如果我沒帶錢互例,則將我的所有袋子里的所有蘋果取出奢入,然后結(jié)束當(dāng)前的“拜訪一家水果店流程”

? ? ? ? 付錢拿走蘋果

? ? ? ? 跳過剩余的“拜訪一家水果店流程”

? ? 拜訪一家水果店流程結(jié)束

買蘋果流程結(jié)束

這個流程怎么樣?我來設(shè)計一些測試樣例媳叨,測試一下這個流程腥光。

測試發(fā)現(xiàn)一個問題:如果水果店0和水果店1都有紅富士蘋果并且價格都低于10元/斤,而且水果店1的價格比水果店0更低糊秆,那么我希望買水果店1的蘋果柴我,但我設(shè)計的流程會讓我買水果店0的蘋果。

為了解決這個問題扩然,我應(yīng)該先詢問所有水果店的價格艘儒,然后去價格最低的那一家買蘋果。

經(jīng)過修改夫偶,我重新設(shè)計出以下的買蘋果的流程:

買蘋果流程開始

? ? 對水果店0界睁、水果店1、水果店2依次執(zhí)行:

? ? 詢問一家水果店的紅富士價格流程開始

? ? ? ? 走到此水果店

? ? ? ? 如果此水果店沒有開門兵拢,則視此水果店的紅富士價格為無窮大元/斤翻斟,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士價格流程”

? ? ? ? 如果此水果店沒有蘋果,則視此水果店的紅富士價格為無窮大元/斤说铃,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士價格流程”

? ? ? ? 如果此水果店的蘋果當(dāng)中沒有紅富士蘋果访惜,則視此水果店的紅富士價格為無窮大元/斤嘹履,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士價格流程”

? ? ? ? 如果此水果店的紅富士蘋果剩余不到一斤,則視此水果店的紅富士價格為無窮大元/斤债热,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士價格流程”

? ? ? ? 向店主詢問此水果店的紅富士蘋果價格并記錄

? ? 詢問一家水果店的紅富士價格流程結(jié)束

? ? 從3家水果店中選出紅富士價格最低的一家(如果有并列則隨機(jī)選擇)砾嫉,將其作為目標(biāo)水果店

? ? 如果目標(biāo)水果店的紅富士蘋果價格為無窮大元/斤,則結(jié)束當(dāng)前的“買蘋果流程”

? ? 走到目標(biāo)水果店

? ? 如果此水果店的紅富士蘋果的價格高于10元/斤窒篱,則執(zhí)行3次:

? ? 講價流程開始

? ? ? ? 詢問店主是否愿意將價格降到10元/斤或更低

? ? ? ? 如果店主愿意焕刮,則跳過剩余的“講價流程”

? ? 講價流程結(jié)束

? ? 如果此水果店的紅富士蘋果的價格仍然高于10元/斤,則結(jié)束當(dāng)前的“買蘋果流程”

? ? 打開一個袋子墙杯,將其作為當(dāng)前的袋子

? ? 重復(fù)執(zhí)行以下流程配并,直到總重量大于一斤:

? ? 裝袋一個蘋果流程開始

? ? ? ? 從所有的不在袋子中的紅富士蘋果中選出最好的一個

? ? ? ? 如果此蘋果能裝入當(dāng)前的袋子,則將此蘋果裝入當(dāng)前的袋子高镐,否則執(zhí)行:

? ? ? ? 換袋子流程開始

? ? ? ? ? ? 如果我有剩余的袋子溉旋,則從中任意選出一個并作為當(dāng)前的袋子嫉髓,否則執(zhí)行:

? ? ? ? ? ? 向店主要袋子流程開始

? ? ? ? ? ? ? ? 向店主索要一個袋子

? ? ? ? ? ? ? ? 如果店主拒絕給我袋子,則將我的所有袋子里的所有蘋果取出岩喷,然后結(jié)束當(dāng)前的“買蘋果流程”

? ? ? ? ? ? ? ? 將店主給我的袋子作為當(dāng)前的袋子

? ? ? ? ? ? 向店主要袋子流程結(jié)束

? ? ? ? 換袋子流程結(jié)束

? ? ? ? 測量我的所有袋子里的所有蘋果的總重量

? ? 裝袋一個蘋果流程結(jié)束

? ? 根據(jù)我的所有袋子里的所有蘋果的總重量和店主給出的價格,計算我應(yīng)付的價格

? ? 向店主詢問我應(yīng)付的價格

? ? 如果我不接受店主索要的價格纱意,則執(zhí)行3次:

? ? 校對流程開始

? ? ? ? 向店主解釋我計算出的價格婶溯,并詢問其是否同意

? ? ? ? 如果店主同意,則跳過剩余的“校對流程”

? ? 校對流程結(jié)束

? ? 如果我仍然不接受店主索要的價格迄委,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“買蘋果流程”

? ? 如果我沒帶錢叙身,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“買蘋果流程”

? ? 付錢拿走蘋果

買蘋果流程結(jié)束

現(xiàn)在這個流程是不是完美了呢硫狞?不是信轿,我還能發(fā)現(xiàn)很多問題。

如果3家水果店都有紅富士蘋果但都不到一斤残吩,但是三家店加起來能達(dá)到一斤,那么我不應(yīng)該結(jié)束流程回家泣侮,而是應(yīng)該把三家店的紅富士蘋果都買下來。

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

我走路的過程中可能會遇到突發(fā)事件,比如發(fā)現(xiàn)了新的水果店稠屠,比如袋子破掉了蘋果掉一地翎苫,對于這些情況我的流程都無法進(jìn)行處理。

啊問題太多了我懶得再改流程了攘蔽。我還是去X寶買吧呐粘。

那么接下來我要設(shè)計一個在X寶買紅富士蘋果的流程……

==========================================================

這篇回答并不是講述在生活中程序員如何買蘋果,而是以買蘋果為例說明程序員如何解決問題作岖。程序員需要對問題進(jìn)行透徹的分析,理清其涉及的所有細(xì)節(jié)痘儡,預(yù)測可能發(fā)生的所有意外與非意外的情況,列出解決方案的所有步驟渐尿,以及對解決方案進(jìn)行盡量全面的測試矾瑰。

而這些正是我認(rèn)為編程難的地方。任何一點(diǎn)遺漏都會成為bug殴穴,輕則導(dǎo)致挨罵凉夯,重則導(dǎo)致經(jīng)濟(jì)損失甚至危害安全采幌。

注意這些難點(diǎn)全部和語言無關(guān)。和編程所需要的絕對嚴(yán)密的邏輯相比植榕,語言實在是太簡單了。(某些自帶代碼混淆效果的語言除外)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末炒瘸,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子拐邪,更是在濱河造成了極大的恐慌隘截,老刑警劉巖扎阶,帶你破解...
    沈念sama閱讀 222,590評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件东臀,死亡現(xiàn)場離奇詭異犀农,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)呵哨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評論 3 399
  • 文/潘曉璐 我一進(jìn)店門孟害,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人挨务,你說我怎么就攤上這事≡抛樱” “怎么了?”我有些...
    開封第一講書人閱讀 169,301評論 0 362
  • 文/不壞的土叔 我叫張陵绒障,是天一觀的道長捍歪。 經(jīng)常有香客問我,道長庐镐,這世上最難降的妖魔是什么变逃? 我笑而不...
    開封第一講書人閱讀 60,078評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮名眉,結(jié)果婚禮上粟矿,老公的妹妹穿的比我還像新娘。我一直安慰自己陌粹,他們只是感情好福压,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,082評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蒙幻,像睡著了一般胞枕。 火紅的嫁衣襯著肌膚如雪杆煞。 梳的紋絲不亂的頭發(fā)上腐泻,一...
    開封第一講書人閱讀 52,682評論 1 312
  • 那天派桩,我揣著相機(jī)與錄音蚌斩,去河邊找鬼。 笑死送膳,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的叠聋。 我是一名探鬼主播,決...
    沈念sama閱讀 41,155評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼虏束,長吁一口氣:“原來是場噩夢啊……” “哼厦章!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起汗侵,我...
    開封第一講書人閱讀 40,098評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎冀值,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體列疗,經(jīng)...
    沈念sama閱讀 46,638評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡浪蹂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,701評論 3 342
  • 正文 我和宋清朗相戀三年坤次,在試婚紗的時候發(fā)現(xiàn)自己被綠了古劲。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片缰猴。...
    茶點(diǎn)故事閱讀 40,852評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡滑绒,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出疑故,到底是詐尸還是另有隱情,我是刑警寧澤纵势,帶...
    沈念sama閱讀 36,520評論 5 351
  • 正文 年R本政府宣布钦铁,位于F島的核電站软舌,受9級特大地震影響牛曹,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜恋脚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,181評論 3 335
  • 文/蒙蒙 一焰手、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧书妻,春花似錦躬拢、人聲如沸见间。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽史侣。三九已至,卻和暖如春惊橱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背税朴。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評論 1 274
  • 我被黑心中介騙來泰國打工正林, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人卓囚。 一個月前我還...
    沈念sama閱讀 49,279評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親贤笆。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,851評論 2 361

推薦閱讀更多精彩內(nèi)容