如果你還在疑惑啥是編程思維魏滚,不如來(lái)看看一個(gè)程序員買蘋果的過程

普通人:

我今天要買一斤蘋果镀首。

>>>>

選自知乎

DJ Hitori

程序員:

我今天要買一斤蘋果。

因?yàn)槲抑幌矚g紅富士蘋果鼠次,所以我只買紅富士蘋果更哄。

我能接受的最高價(jià)格是10元/斤。

正常情況下一斤蘋果用一個(gè)袋子能裝下腥寇,但是為防萬(wàn)一成翩,我會(huì)帶兩個(gè)袋子。

我知道附近的3家水果店赦役,所以我會(huì)依次訪問這3家水果店麻敌。

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

1掂摔、買蘋果流程開始 ? ?

2术羔、對(duì)水果店0、水果店1乙漓、水果店2依次執(zhí)行: ? ?

3级历、拜訪一家水果店流程開始 ? ? ? ?

4、走到此水果店 ? ? ? ?

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

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

7扛禽、如果此水果店的蘋果當(dāng)中沒有紅富士蘋果,則結(jié)束當(dāng)前的“拜訪一家水果店流程”? ? ? 8皱坛、如果此水果店的紅富士蘋果剩余不到一斤编曼,則結(jié)束當(dāng)前的“拜訪一家水果店流程”? ? ? 9、如果此水果店的紅富士蘋果的價(jià)格高于10元/斤剩辟,則執(zhí)行3次: ? ? ? ?

10掐场、講價(jià)流程開始 ? ? ? ? ? ?

11往扔、詢問店主是否愿意將價(jià)格降到10元/斤或更低 ? ? ? ? ? ?

12、如果店主愿意熊户,則跳過剩余的“講價(jià)流程” ? ? ? ?

13萍膛、講價(jià)流程結(jié)束 ? ? ? ?

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

15蝗罗、打開一個(gè)袋子,將其作為當(dāng)前的袋子? ? 16蝌戒、重復(fù)執(zhí)行以下流程串塑,直到總重量大于一斤: ? ? ? ?

17、裝袋一個(gè)蘋果流程開始 ? ? ? ? ? ?

18北苟、從所有的不在袋子中的紅富士蘋果中選出最好的一個(gè) ? ? ? ? ? ?

19桩匪、如果此蘋果能裝入當(dāng)前的袋子,則將此蘋果裝入當(dāng)前的袋子友鼻,否則執(zhí)行:? ? ? ? ? ? 20傻昙、換袋子流程開始 ? ? ? ? ? ? ? ?

21、如果我有剩余的袋子桃移,則從中任意選出一個(gè)并作為當(dāng)前的袋子屋匕,否則執(zhí)行:? ? ? ? ? 22、向店主要袋子流程開始? ? ? ? ? ? ? ? ? ? 23借杰、向店主索要一個(gè)袋子 ? ? ? ? ? ? ? ? ? ?

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

25纤虽、將店主給我的袋子作為當(dāng)前的袋子? ? ? 26、向店主要袋子流程結(jié)束 ? ? ? ? ? ?

27绞惦、換袋子流程結(jié)束 ? ? ? ? ? ?

28逼纸、測(cè)量我的所有袋子里的所有蘋果的總重量 ? ? ? ?

29、裝袋一個(gè)蘋果流程結(jié)束 ? ? ? ?

30济蝉、根據(jù)我的所有袋子里的所有蘋果的總重量和店主給出的價(jià)格杰刽,計(jì)算我應(yīng)付的價(jià)格? ? 31、向店主詢問我應(yīng)付的價(jià)格 ? ? ? ?

32王滤、如果我不接受店主索要的價(jià)格贺嫂,則執(zhí)行3次: ? ? ? ?

33、校對(duì)流程開始 ? ? ? ? ? ?

34雁乡、向店主解釋我計(jì)算出的價(jià)格第喳,并詢問其是否同意 ? ? ? ? ? ?

35、如果店主同意踱稍,則跳過剩余的“校對(duì)流程” ? ? ? ?

36曲饱、校對(duì)流程結(jié)束 ? ? ? ?

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

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

39梁丘、付錢拿走蘋果 ? ? ? ?

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

41旺韭、拜訪一家水果店流程結(jié)束

42、買蘋果流程結(jié)束

這個(gè)流程怎么樣掏觉?我來(lái)設(shè)計(jì)一些測(cè)試樣例区端,測(cè)試一下這個(gè)流程。

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

為了解決這個(gè)問題沥邻,我應(yīng)該先詢問所有水果店的價(jià)格,然后去價(jià)格最低的那一家買蘋果羊娃。

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

1、買蘋果流程開始 ? ?

2蕊玷、對(duì)水果店0邮利、水果店1、水果店2依次執(zhí)行: ? ?

3垃帅、詢問一家水果店的紅富士?jī)r(jià)格流程開始? ? 4延届、走到此水果店 ? ? ? ?

5、如果此水果店沒有開門贸诚,則視此水果店的紅富士?jī)r(jià)格為無(wú)窮大元/斤方庭,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士?jī)r(jià)格流程”? ? ? ?

6、如果此水果店沒有蘋果酱固,則視此水果店的紅富士?jī)r(jià)格為無(wú)窮大元/斤械念,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士?jī)r(jià)格流程”? ? ? ??

7、如果此水果店的蘋果當(dāng)中沒有紅富士蘋果媒怯,則視此水果店的紅富士?jī)r(jià)格為無(wú)窮大元/斤订讼,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士?jī)r(jià)格流程” ? ? ? ?

8、如果此水果店的紅富士蘋果剩余不到一斤扇苞,則視此水果店的紅富士?jī)r(jià)格為無(wú)窮大元/斤欺殿,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士?jī)r(jià)格流程” ? ? ? ?

9寄纵、向店主詢問此水果店的紅富士蘋果價(jià)格并記錄 ? ?

10、詢問一家水果店的紅富士?jī)r(jià)格流程結(jié)束? 11脖苏、從3家水果店中選出紅富士?jī)r(jià)格最低的一家(如果有并列則隨機(jī)選擇)腐晾,將其作為目標(biāo)水果店 ? ?

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

13匠童、走到目標(biāo)水果店 ? ?

14、如果此水果店的紅富士蘋果的價(jià)格高于10元/斤亦歉,則執(zhí)行3次: ? ?

15恤浪、講價(jià)流程開始 ? ? ? ?

16、詢問店主是否愿意將價(jià)格降到10元/斤或更低 ? ? ? ?

17肴楷、如果店主愿意水由,則跳過剩余的“講價(jià)流程” ? ?

18、講價(jià)流程結(jié)束 ? ?

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

20、打開一個(gè)袋子呵恢,將其作為當(dāng)前的袋子? ? 21鞠值、重復(fù)執(zhí)行以下流程,直到總重量大于一斤: ? ?

22渗钉、裝袋一個(gè)蘋果流程開始 ? ? ? ?

23彤恶、從所有的不在袋子中的紅富士蘋果中選出最好的一個(gè) ? ? ? ?

24、如果此蘋果能裝入當(dāng)前的袋子晌姚,則將此蘋果裝入當(dāng)前的袋子粤剧,否則執(zhí)行: ? ? ? ?

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

26挥唠、如果我有剩余的袋子抵恋,則從中任意選出一個(gè)并作為當(dāng)前的袋子,否則執(zhí)行:?? ? ? ??

27宝磨、向店主要袋子流程開始 ? ? ? ? ? ? ? ?

28弧关、向店主索要一個(gè)袋子 ? ? ? ? ? ? ? ?

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

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

31窿祥、向店主要袋子流程結(jié)束 ? ? ? ?

32株憾、換袋子流程結(jié)束 ? ? ? ?

33、測(cè)量我的所有袋子里的所有蘋果的總重量 ? ?

34、裝袋一個(gè)蘋果流程結(jié)束 ? ?

35嗤瞎、根據(jù)我的所有袋子里的所有蘋果的總重量和店主給出的價(jià)格墙歪,計(jì)算我應(yīng)付的價(jià)格??

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

37贝奇、如果我不接受店主索要的價(jià)格虹菲,則執(zhí)行3次: ? ?

38、校對(duì)流程開始 ? ? ? ?

39掉瞳、向店主解釋我計(jì)算出的價(jià)格毕源,并詢問其是否同意 ? ? ? ?

40、如果店主同意陕习,則跳過剩余的“校對(duì)流程” ? ?

41霎褐、校對(duì)流程結(jié)束 ? ?

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

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

44歌粥、付錢拿走蘋果

45塌忽、買蘋果流程結(jié)束

現(xiàn)在這個(gè)流程是不是完美了呢?不是失驶,我還能發(fā)現(xiàn)很多問題土居。

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

如果我向水果店詢問價(jià)格的時(shí)候這家店還有紅富士蘋果涩堤,但我詢問完所有水果店的價(jià)格后這家店的紅富士蘋果賣完了眷蜓,那么我的流程會(huì)讓我試圖處理不存在的紅富士蘋果。

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

啊問題太多了我懶得再改流程了汽纤。我還是去X寶買吧。

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

在這里可能會(huì)有家長(zhǎng)說(shuō):不就是買一份蘋果嗎福荸?至于這樣麻煩嗎蕴坪?

嘿,還真就至于敬锐,透過現(xiàn)象看本質(zhì)背传,為什么很多孩子學(xué)不懂?dāng)?shù)學(xué)捆等、學(xué)不懂語(yǔ)文,因?yàn)樗麄內(nèi)狈@樣解題的清晰條例续室,這里稱為邏輯思維栋烤。如果在做數(shù)學(xué)題、語(yǔ)文問題的時(shí)候挺狰,孩子們按照上述這種思維去解題明郭,那么,問題自然而然就迎刃而解丰泊。

這篇敘述并不是講述在生活中程序員如何買蘋果薯定,而是以買蘋果為例說(shuō)明程序員如何解決問題。程序員需要對(duì)問題進(jìn)行透徹的分析瞳购,理清其涉及的所有細(xì)節(jié)话侄,預(yù)測(cè)可能發(fā)生的所有意外與非意外的情況,列出解決方案的所有步驟学赛,以及對(duì)解決方案進(jìn)行盡量全面的測(cè)試年堆。

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

注意這些難點(diǎn)全部和語(yǔ)言無(wú)關(guān)绢掰。和編程所需要的絕對(duì)嚴(yán)密的邏輯相比痒蓬,語(yǔ)言實(shí)在是太簡(jiǎn)單了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末滴劲,一起剝皮案震驚了整個(gè)濱河市攻晒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌班挖,老刑警劉巖鲁捏,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異聪姿,居然都是意外死亡碴萧,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門末购,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)破喻,“玉大人,你說(shuō)我怎么就攤上這事盟榴〔苤剩” “怎么了?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)羽德。 經(jīng)常有香客問我几莽,道長(zhǎng),這世上最難降的妖魔是什么宅静? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任章蚣,我火速辦了婚禮,結(jié)果婚禮上姨夹,老公的妹妹穿的比我還像新娘纤垂。我一直安慰自己,他們只是感情好磷账,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布峭沦。 她就那樣靜靜地躺著,像睡著了一般逃糟。 火紅的嫁衣襯著肌膚如雪吼鱼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天绰咽,我揣著相機(jī)與錄音菇肃,去河邊找鬼。 笑死剃诅,一個(gè)胖子當(dāng)著我的面吹牛巷送,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播矛辕,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼付魔!你這毒婦竟也來(lái)了聊品?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤几苍,失蹤者是張志新(化名)和其女友劉穎翻屈,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體妻坝,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡伸眶,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了刽宪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片厘贼。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖圣拄,靈堂內(nèi)的尸體忽然破棺而出嘴秸,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布岳掐,位于F島的核電站凭疮,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏串述。R本人自食惡果不足惜执解,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望纲酗。 院中可真熱鬧衰腌,春花似錦、人聲如沸耕姊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)茉兰。三九已至尤泽,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間规脸,已是汗流浹背坯约。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留莫鸭,地道東北人闹丐。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像被因,于是被迫代替她去往敵國(guó)和親卿拴。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353