編程基本功訓練:流程圖畫法及練習


對於“程序設計”的工作,很多剛開始學習的人的理解就是“寫代碼”。相同,新手們苦惱的問題是,他們僅僅會“寫代碼”。當接到一個新的任務,不少人總是在第一時間就爬到鍵盤上去敲代碼。敲着敲着,就把自己繞糊塗了。頭暈腦脹地堅持下來,程序能執行,阿彌托佛,趕緊撤。這樣做出的程序,並不可靠。
  在程序設計中,最重要的不是敲代碼,而是設計。就像建築、機械等行業的要畫設計圖、施工圖,程序設計的思路也有必要用圖的形式畫出來。繪圖的過程就是思考的過程,因為其直觀性,繪圖的過程本身又促進了思考。在軟件project中,已經發展出了非常多種有用的圖,為軟件產品設計的質量提供保證。這部分練習幫助程序設計者掌握和實踐的“程序流程圖”。
  一、什么是程序流程圖

  “程序流程圖”常簡稱為“流程圖”,是一種傳統的算法表示法,程序流程圖是人們對解決這個問題的方法、思路或算法的一種描寫敘述。它利用圖形化的符號框來代表各種不同性質的操作,並用流程線來連接這些操作。在程序的設計(在編碼之前)階段,通過畫流程圖,能夠幫助我們理清程序思路。下圖是一個簡單的流程圖,描寫敘述求兩個數的最大公約數的算法(輾轉相除法)。

    

  畫流程圖是每一個程序猿的基本功。流程圖有其規范,這是用於技術人員之間交流的須要,並非想怎么畫就怎么畫。流程圖中經常使用的符號見右圖,在前述求最大公約數的流程圖中找出相應的部分。


  二、三種控制結構的流程圖表示

  這部分不再寫文字,各種程序設計的教材中都會寫一些,至少在講各種控制結構時,總時要講的。請參考自己手頭能找到的教材,認真品味。
  我們直接提示若干任務,畫一畫,就會了。


  三、練習題目(各部分分別至少選兩個畫一畫,注意用一張質量好一些紙,書寫整齊,確保越畫越高興)

  1、熱身
  (1)將英尺轉換為米
  (2)輸入兩個點的坐標,求兩點之間的距離並輸出
  2、分支程序
  (1)描寫敘述一下今晚的計划:假設下雪,校園內玩雪;否則,在103上機(懷念)
  (2)丟硬幣決定今晚:正面,K歌;反面:逛街;立起來,學C++

  (3)求函數值:

  

  

  (4)輸入一元二次方程ax^2+bx+c=0的各項系數,並依據各系數的值的情況,分別進行求解(考慮對系數的各種可能太復雜時,給自己減少些難度,先從不考慮系統直接求解開始)
  (5)輸入個人月收入總額,計算出他本月應繳稅款和稅后收入(稅率等參考第9周任務) 
  3、循環結構
  (1)求1+2+3+...+100(三種循環結構都畫一畫)
  (2)輸出1/3-3/5+5/7-7/9…+19/21的結果 
  (3)一個數假設恰好等於它的因子之和,這個數就稱為“完數”。找出1000內的全部完數。
  (4)輸出1000以內的全部回文數
  (5)雞翁一,值錢五,雞母一,值錢三,雞雛三,值錢一,百錢買百雞,怎樣買? 
  4、復雜結構的程序

  在解決這個問題中,利用函數能夠讓我們利用更“有序”的思維去想問題,“自頂向下,逐步求精”,真理。例:以下的流程圖用於輸出星號圖,體現的是這樣的思維,右邊的圖能夠嵌入到左邊中,替代“輸出第i行”的框子,也能夠指導我們專門編成一個函數。

  

  任務:
  (1)輸出10000以內的全部回文素數。將推斷回文和推斷素數分別單獨畫,相應將這兩個功能用函數實現的方法。
  (2)畫出銀行系統的流程圖(各詳細業務點到為止,不必全畫)


  注:在傳統教學中,未學寫代碼,先學畫流程。曾經的實踐中,感覺效果不好。控制結構為何物都暈,怎樣能畫出來。有一定編程體驗后再畫,是改革的思路。這是編程的一項基本功,務必掌握!



  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM