普通人:
我今天要買一斤蘋果。
程序員:
我今天要買一斤蘋果。
因?yàn)槲抑幌矚g紅富士蘋果,所以我只買紅富士蘋果。
我能接受的最高價(jià)格是10元/斤。
正常情況下一斤蘋果用一個(gè)袋子能裝下,但是為防萬一,我會(huì)帶兩個(gè)袋子。
我知道附近的3家水果店,所以我會(huì)依次訪問這3家水果店。
根據(jù)上述條件,我設(shè)計(jì)出以下的買蘋果的流程:
買蘋果流程開始 對(duì)水果店0、水果店1、水果店2依次執(zhí)行: 拜訪一家水果店流程開始 走到此水果店 如果此水果店沒有開門,則結(jié)束當(dāng)前的“拜訪一家水果店流程” 如果此水果店沒有蘋果,則結(jié)束當(dāng)前的“拜訪一家水果店流程” 如果此水果店的蘋果當(dāng)中沒有紅富士蘋果,則結(jié)束當(dāng)前的“拜訪一家水果店流程” 如果此水果店的紅富士蘋果剩余不到一斤,則結(jié)束當(dāng)前的“拜訪一家水果店流程” 如果此水果店的紅富士蘋果的價(jià)格高于10元/斤,則執(zhí)行3次: 講價(jià)流程開始 詢問店主是否愿意將價(jià)格降到10元/斤或更低 如果店主愿意,則跳過剩余的“講價(jià)流程” 講價(jià)流程結(jié)束 如果此水果店的紅富士蘋果的價(jià)格仍然高于10元/斤,則結(jié)束當(dāng)前的“拜訪一家水果店流程” 打開一個(gè)袋子,將其作為當(dāng)前的袋子 重復(fù)執(zhí)行以下流程,直到總重量大于一斤: 裝袋一個(gè)蘋果流程開始 從所有的不在袋子中的紅富士蘋果中選出最好的一個(gè) 如果此蘋果能裝入當(dāng)前的袋子,則將此蘋果裝入當(dāng)前的袋子,否則執(zhí)行: 換袋子流程開始 如果我有剩余的袋子,則從中任意選出一個(gè)并作為當(dāng)前的袋子,否則執(zhí)行: 向店主要袋子流程開始 向店主索要一個(gè)袋子 如果店主拒絕給我袋子,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“拜訪一家水果店流程” 將店主給我的袋子作為當(dāng)前的袋子 向店主要袋子流程結(jié)束 換袋子流程結(jié)束 測(cè)量我的所有袋子里的所有蘋果的總重量 裝袋一個(gè)蘋果流程結(jié)束 根據(jù)我的所有袋子里的所有蘋果的總重量和店主給出的價(jià)格,計(jì)算我應(yīng)付的價(jià)格 向店主詢問我應(yīng)付的價(jià)格 如果我不接受店主索要的價(jià)格,則執(zhí)行3次: 校對(duì)流程開始 向店主解釋我計(jì)算出的價(jià)格,并詢問其是否同意 如果店主同意,則跳過剩余的“校對(duì)流程” 校對(duì)流程結(jié)束 如果我仍然不接受店主索要的價(jià)格,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“拜訪一家水果店流程” 如果我沒帶錢,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“拜訪一家水果店流程” 付錢拿走蘋果 跳過剩余的“拜訪一家水果店流程” 拜訪一家水果店流程結(jié)束 買蘋果流程結(jié)束
這個(gè)流程怎么樣?我來設(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ì)出以下的買蘋果的流程:
買蘋果流程開始 對(duì)水果店0、水果店1、水果店2依次執(zhí)行: 詢問一家水果店的紅富士?jī)r(jià)格流程開始 走到此水果店 如果此水果店沒有開門,則視此水果店的紅富士?jī)r(jià)格為無窮大元/斤,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士?jī)r(jià)格流程” 如果此水果店沒有蘋果,則視此水果店的紅富士?jī)r(jià)格為無窮大元/斤,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士?jī)r(jià)格流程” 如果此水果店的蘋果當(dāng)中沒有紅富士蘋果,則視此水果店的紅富士?jī)r(jià)格為無窮大元/斤,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士?jī)r(jià)格流程” 如果此水果店的紅富士蘋果剩余不到一斤,則視此水果店的紅富士?jī)r(jià)格為無窮大元/斤,并結(jié)束當(dāng)前的“詢問一家水果店的紅富士?jī)r(jià)格流程” 向店主詢問此水果店的紅富士蘋果價(jià)格并記錄 詢問一家水果店的紅富士?jī)r(jià)格流程結(jié)束 從3家水果店中選出紅富士?jī)r(jià)格最低的一家(如果有并列則隨機(jī)選擇),將其作為目標(biāo)水果店 如果目標(biāo)水果店的紅富士蘋果價(jià)格為無窮大元/斤,則結(jié)束當(dāng)前的“買蘋果流程” 走到目標(biāo)水果店 如果此水果店的紅富士蘋果的價(jià)格高于10元/斤,則執(zhí)行3次: 講價(jià)流程開始 詢問店主是否愿意將價(jià)格降到10元/斤或更低 如果店主愿意,則跳過剩余的“講價(jià)流程” 講價(jià)流程結(jié)束 如果此水果店的紅富士蘋果的價(jià)格仍然高于10元/斤,則結(jié)束當(dāng)前的“買蘋果流程” 打開一個(gè)袋子,將其作為當(dāng)前的袋子 重復(fù)執(zhí)行以下流程,直到總重量大于一斤: 裝袋一個(gè)蘋果流程開始 從所有的不在袋子中的紅富士蘋果中選出最好的一個(gè) 如果此蘋果能裝入當(dāng)前的袋子,則將此蘋果裝入當(dāng)前的袋子,否則執(zhí)行: 換袋子流程開始 如果我有剩余的袋子,則從中任意選出一個(gè)并作為當(dāng)前的袋子,否則執(zhí)行: 向店主要袋子流程開始 向店主索要一個(gè)袋子 如果店主拒絕給我袋子,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“買蘋果流程” 將店主給我的袋子作為當(dāng)前的袋子 向店主要袋子流程結(jié)束 換袋子流程結(jié)束 測(cè)量我的所有袋子里的所有蘋果的總重量 裝袋一個(gè)蘋果流程結(jié)束 根據(jù)我的所有袋子里的所有蘋果的總重量和店主給出的價(jià)格,計(jì)算我應(yīng)付的價(jià)格 向店主詢問我應(yīng)付的價(jià)格 如果我不接受店主索要的價(jià)格,則執(zhí)行3次: 校對(duì)流程開始 向店主解釋我計(jì)算出的價(jià)格,并詢問其是否同意 如果店主同意,則跳過剩余的“校對(duì)流程” 校對(duì)流程結(jié)束 如果我仍然不接受店主索要的價(jià)格,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“買蘋果流程” 如果我沒帶錢,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當(dāng)前的“買蘋果流程” 付錢拿走蘋果 買蘋果流程結(jié)束
現(xiàn)在這個(gè)流程是不是完美了呢?不是,我還能發(fā)現(xiàn)很多問題。
如果3家水果店都有紅富士蘋果但都不到一斤,但是三家店加起來能達(dá)到一斤,那么我不應(yīng)該結(jié)束流程回家,而是應(yīng)該把三家店的紅富士蘋果都買下來。
如果我向水果店詢問價(jià)格的時(shí)候這家店還有紅富士蘋果,但我詢問完所有水果店的價(jià)格后這家店的紅富士蘋果賣完了,那么我的流程會(huì)讓我試圖處理不存在的紅富士蘋果。
我走路的過程中可能會(huì)遇到突發(fā)事件,比如發(fā)現(xiàn)了新的水果店,比如袋子破掉了蘋果掉一地,對(duì)于這些情況我的流程都無法進(jìn)行處理。
啊問題太多了我懶得再改流程了。我還是去X寶買吧。
那么接下來我要設(shè)計(jì)一個(gè)在X寶買紅富士蘋果的流程……
==========================================================
-----來自知乎