普通人:我今天要買一斤蘋果。程序員
程序員:我今天要買一斤蘋果。編程
由於我只喜歡紅富士蘋果,因此我只買紅富士蘋果。微信
我能接受的最高價格是10元/斤。學習
正常狀況下一斤蘋果用一個袋子能裝下,可是爲防萬一,我會帶兩個袋子。測試
我知道附近的 3 家水果店,因此我會依次訪問這 3 家水果店。spa
根據上述條件,我設計出如下的買蘋果的流程:設計
買蘋果流程開始blog
對水果店 0 、水果店 1 、水果店 2 依次執行:事件
拜訪一家水果店流程開始get
走到此水果店
若是此水果店沒有開門,則結束當前的「拜訪一家水果店流程」
若是此水果店沒有蘋果,則結束當前的「拜訪一家水果店流程」
若是此水果店的蘋果當中沒有紅富士蘋果,則結束當前的「拜訪一家水果店流程」
若是此水果店的紅富士蘋果剩餘不到一斤,則結束當前的「拜訪一家水果店流程」
若是此水果店的紅富士蘋果的價格高於 10 元/斤,則執行 3 次:
講價流程開始
詢問店主是否願意將價格降到 10 元/斤或更低
若是店主願意,則跳過剩餘的「講價流程」
講價流程結束
若是此水果店的紅富士蘋果的價格仍然高於 10 元/斤,則結束當前的「拜訪一家水果店流程」
打開一個袋子,將其做爲當前的袋子
重複執行如下流程,直到總重量大於一斤:
裝袋一個蘋果流程開始
從全部的不在袋子中的紅富士蘋果中選出最好的一個
若是此蘋果能裝入當前的袋子,則將此蘋果裝入當前的袋子,不然執行:
換袋子流程開始
若是我有剩餘的袋子,則從中任意選出一個並做爲當前的袋子,不然執行:
向店主要袋子流程開始
向店主索要一個袋子
若是店主拒絕給我袋子,則將個人全部袋子裏的全部蘋果取出,而後結束當前的「拜訪一家水果店流程」
將店主給個人袋子做爲當前的袋子
向店主要袋子流程結束
換袋子流程結束
測量個人全部袋子裏的全部蘋果的總重量
裝袋一個蘋果流程結束
根據個人全部袋子裏的全部蘋果的總重量和店主給出的價格,計算我應付的價格
向店主詢問我應付的價格
若是我不接受店主索要的價格,則執行 3 次:
校對流程開始
向店主解釋我計算出的價格,並詢問其是否贊成
若是店主贊成,則跳過剩餘的「校對流程」
校對流程結束
若是我仍然不接受店主索要的價格,則將個人全部袋子裏的全部蘋果取出,而後結束當前的「拜訪一家水果店流程」
若是我沒帶錢,則將個人全部袋子裏的全部蘋果取出,而後結束當前的「拜訪一家水果店流程」
付錢拿走蘋果
跳過剩餘的「拜訪一家水果店流程」
拜訪一家水果店流程結束
買蘋果流程結束
這個流程怎麼樣?我來設計一些測試樣例,測試一下這個流程。
測試發現一個問題:若是水果店 0 和水果店 1 都有紅富士蘋果而且價格都低於 10 元/斤,並且水果店 1 的價格比水果店 0 更低,那麼我但願買水果店 1 的蘋果,但我設計的流程會讓我買水果店 0 的蘋果。
爲了解決這個問題,我應該先詢問全部水果店的價格,而後去價格最低的那一家買蘋果。
通過修改,我從新設計出如下的買蘋果的流程:
買蘋果流程開始
對水果店 0 、水果店 1 、水果店 2 依次執行:
詢問一家水果店的紅富士價格流程開始
走到此水果店
若是此水果店沒有開門,則視此水果店的紅富士價格爲無窮大元/斤,並結束當前的「詢問一家水果店的紅富士價格流程」
若是此水果店沒有蘋果,則視此水果店的紅富士價格爲無窮大元/斤,並結束當前的「詢問一家水果店的紅富士價格流程」
若是此水果店的蘋果當中沒有紅富士蘋果,則視此水果店的紅富士價格爲無窮大元/斤,並結束當前的「詢問一家水果店的紅富士價格流程」
若是此水果店的紅富士蘋果剩餘不到一斤,則視此水果店的紅富士價格爲無窮大元/斤,並結束當前的「詢問一家水果店的紅富士價格流程」
向店主詢問此水果店的紅富士蘋果價格並記錄
詢問一家水果店的紅富士價格流程結束
從3家水果店中選出紅富士價格最低的一家(若是有並列則隨機選擇),將其做爲目標水果店
若是目標水果店的紅富士蘋果價格爲無窮大元/斤,則結束當前的「買蘋果流程」
走到目標水果店
若是此水果店的紅富士蘋果的價格高於 10 元/斤,則執行 3 次:
講價流程開始
詢問店主是否願意將價格降到 10 元/斤或更低
若是店主願意,則跳過剩餘的「講價流程」
講價流程結束
若是此水果店的紅富士蘋果的價格仍然高於 10 元/斤,則結束當前的「買蘋果流程」
打開一個袋子,將其做爲當前的袋子
重複執行如下流程,直到總重量大於一斤:
裝袋一個蘋果流程開始
從全部的不在袋子中的紅富士蘋果中選出最好的一個
若是此蘋果能裝入當前的袋子,則將此蘋果裝入當前的袋子,不然執行:
換袋子流程開始
若是我有剩餘的袋子,則從中任意選出一個並做爲當前的袋子,不然執行:
向店主要袋子流程開始
向店主索要一個袋子
若是店主拒絕給我袋子,則將個人全部袋子裏的全部蘋果取出,而後結束當前的「買蘋果流程」
將店主給個人袋子做爲當前的袋子
向店主要袋子流程結束
換袋子流程結束
測量個人全部袋子裏的全部蘋果的總重量
裝袋一個蘋果流程結束
根據個人全部袋子裏的全部蘋果的總重量和店主給出的價格,計算我應付的價格
向店主詢問我應付的價格
若是我不接受店主索要的價格,則執行3次:
校對流程開始
向店主解釋我計算出的價格,並詢問其是否贊成
若是店主贊成,則跳過剩餘的「校對流程」
校對流程結束
若是我仍然不接受店主索要的價格,則將個人全部袋子裏的全部蘋果取出,而後結束當前的「買蘋果流程」
若是我沒帶錢,則將個人全部袋子裏的全部蘋果取出,而後結束當前的「買蘋果流程」
付錢拿走蘋果
買蘋果流程結束
如今這個流程是否是完美了呢?
不是,我還能發現不少問題。
若是 3 家水果店都有紅富士蘋果但都不到一斤,可是三家店加起來能達到一斤,那麼我不該該結束流程回家,而是應該把三家店的紅富士蘋果都買下來。
若是我向水果店詢問價格的時候這家店還有紅富士蘋果,但我詢問完全部水果店的價格後這家店的紅富士蘋果賣完了,那麼個人流程會讓我試圖處理不存在的紅富士蘋果。
我走路的過程當中可能會遇到突發事件,好比發現了新的水果店,好比袋子破掉了蘋果掉一地,對於這些狀況個人流程都沒法進行處理。
問題太多了我懶得再改流程了。
我仍是去某寶買吧。那麼接下來我要設計一個在某寶買紅富士蘋果的流程……
自學C/C++編程難度很大,不妨和一些志同道合的小夥伴一塊兒學習成長!
C語言C++編程學習交流圈子,【點擊進入】微信公衆號:C語言編程學習基地
有一些源碼和資料分享,歡迎轉行也學習編程的夥伴,和你們一塊兒交流成長會比本身琢磨更快哦!