什麽是演算法教案

上传人:新** 文档编号:569238503 上传时间:2024-07-28 格式:PPT 页数:22 大小:157.50KB
返回 下载 相关 举报
什麽是演算法教案_第1页
第1页 / 共22页
什麽是演算法教案_第2页
第2页 / 共22页
什麽是演算法教案_第3页
第3页 / 共22页
什麽是演算法教案_第4页
第4页 / 共22页
什麽是演算法教案_第5页
第5页 / 共22页
点击查看更多>>
资源描述

《什麽是演算法教案》由会员分享,可在线阅读,更多相关《什麽是演算法教案(22页珍藏版)》请在金锄头文库上搜索。

1、什麽是演算法Stillwatersrundeep.流静水深流静水深,人静心深人静心深Wherethereislife,thereishope。有生命必有希望。有生命必有希望什麼是演算法?n面對問題時會研擬出解決問題的步驟,在電腦領域中對於解決問題的方法稱為演算法。n一組可以用來解決特定問題的有限指令或步驟,依循這些指令或步驟可以解決問題。 n演算法是達成一項特定工作的程序。什麼是演算法?“computer” 問題problem演算法algorithm輸入input輸出output至少一個多個或是沒有明確有限可實現有效率學習演算法的問題n專有名詞不了解遇到這種情形, 請翻開教科書找到這些專有名詞

2、的地方, 把它 K 懂並背下來, 這是你這門科目要繼續往下走的先決條件。n所使用的邏輯看不懂n名詞看得懂, 邏輯也了解, 但不會用程式解問題學習演算法的問題n專有名詞不懂n所使用的邏輯看不懂請你先用人腦的方式去想像, 程式這樣做, 相當於人在解決這個問題時的什麼動作, 電腦因為速度快, 有時候會用一些看似愚蠢, 但是完全沒有例外的方法做事, 這就是演算法的精神-充分利用電腦的長處, 它可以用比你笨一千倍的方法做得比你好, 因為它比你快十億倍。n名詞看得懂, 邏輯也了解, 但不會用程式解問題學習演算法的問題n專有名詞不懂n所使用的邏輯看不懂n名詞看得懂, 邏輯也了解, 但不會用程式解問題這個就比

3、較麻煩了, 如果真心想學好程式設計 (“程式設計 = 資料結構 + 演算法” ), 那就要多練習題目了。資料結構是演算法的基礎, 程式寫不出來, 大多數和想不出能讓演算法變單純的資料結構有關, 請回過頭多磨練資料結構的知識吧。 演算法的特性1. 完整性 :演算法中的每個程序都要能清楚地定義出來,不能有模糊不清的情況,只有要求每個程序都明確可行,整個演算法才是完整的。 2. 明確性 :演算法中的程序代表的涵義須明確,任何人來解讀都能得到一致的結果。 3. 可決定性 (Deterministic):在明確而定義清楚的程序被執行後,演算法所達到的結果應該是可預期的,無法具備這種特性的程序的組合,並不

4、能算是演算法。 4. 有限的 (Finite):演算法必須要能在有限的步驟內完成或終止,而且所使用的資料量也是有限的。 所以我們可以把它們看成是演算法的基本定義,滿足這些條件才算是演算法 演算法的其他特性1. 健全的結構:演算法最好具有易懂易用的特性,讓別人能很快地熟悉其用法,所以一般都會要求演算法有良好的結構,組成的元件有容易替代與再用的特性。 2. 一般通用性(Generality):演算法最好能用來解決很多種問題,而不是只用在罕見的特例,既然花了功夫深入去描述一種演算法,自然會要求演算法具有多種用途。 3. 效率(Efficiency):演算法使用時所耗用的系統資源狀況,以及執行的效率,

5、對於使用者而言,是非常重要的問題。因為有時候不但要求解答,還得在有限時間之內完成。 演算法的表達演算法的表達方式,我們可以把它看成是一種溝通的方法,到目前為止,並沒有那一種表示法是公認的標準,事實上也無此必要,一般人在描述演算法時必須講求精準明確,但不必遵循嚴謹的語法,不過,一旦要把演算法交付給電腦來執行時,當然就得十分地講究,因為電腦的邏輯與算術運算是完全依照所給的指令來進行的。 演算法表示最簡單的表示法應該算是口語,或者說白話的講法,例如我們在判定某一年份是不是閏年時,會先看看能否被4整除,若是能被4整除但不能被100整除,可算是閏年,若是能被4整除,又能被100整除,但不能被400整除,

6、則不能算閏年。像這一類的描述就很類似演算法,只是口語的表達方式有時候太繁複了,所以我們下面要介紹一些比較方便的表示法。 演算法表示方法一、 代數的表示法二、表格式的表示法例如申報所得稅時所用的累進稅表,從表格中的資訊可計算出應該繳的所得稅。 三、資料流程圖四、控制流程圖五、類程式碼閏年的判定問題閏年和一般年份最大的差異在於閏年的二月份有29天,一般年的二月只有28天;能被400整除的年份一定是閏年。能被100整除但不能被400整除的,不是閏年。能被4整除但不能被100整除的年份是閏年。不能被4整除的年份不是閏年。 演算法表示方法三、資料流程圖演算法表示方法四、控制流程圖閏年的判定問題閏年的判定

7、問題把閏年判定的問題同時分配給幾個人來求解,所得到的答案不見得和上圖一樣 同樣的問題可能有多種可行的演算法,這些演算法的效率和使用的資源各不相同 。類程式碼(Pseudocode)n它是一種很接近程式語言的演算法敘述,假如能把一個問題的解決方式用類程式碼來表達,就可以很容易的轉換成電腦能處理的指令 。 n類程式碼和一般的程式語言不同,比較不遵循嚴謹的語法,但是在表達與溝通上相當地方便。 類程式碼(Pseudocode)n結合數學式子,敘述與程式控制結構語法n可以採用任何語言為基礎n以能明確表達出演算法為主(流程與運算),對於宣告,輸入與輸出等不會要求像程式一樣明確定義演算法結構演算法中的操作在組合之後,顯示出來的架構;因為某些操作可能代表一個完整的功能,而演算法的整體功能就是這些個別功能的組合。 演算法設計n從問題的需求面開始,確定演算法應該提供的主要功能,然後看看這個功能可由那些次功能來完成,一步一步地把細節規劃出來,這種設計的方法叫做 由上而下的設計 (Top-down design)演算法設計HW1n假設華氏與攝氏溫度的轉換公式可以用 C=(F-32)n(5/9),試用DFD來表示。n試使用虛擬碼撰寫閏年計算的演算法

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 资格认证/考试 > 自考

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号