如何用計算機解決問題課件_第1頁
如何用計算機解決問題課件_第2頁
如何用計算機解決問題課件_第3頁
如何用計算機解決問題課件_第4頁
如何用計算機解決問題課件_第5頁
已閱讀5頁,還剩39頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

算法描述與設計算法描述與設計1

一個人想用船把狼、羊和一箱菜運送到河對面,但是有兩個條件:

(1)船一次只能運一樣;

(2)當人不在時,狼會吃羊,羊會吃菜。一個人想用船把狼、羊和一箱菜運送到河對面,但是2第一步:運羊過河,回來第二步:運菜過河,并運羊回來第三步:運狼過河,回來第四步:運羊過河將過河的方法描述出來:第一步:運羊過河,回來3

一、算法的概念1、算法就是解決問題的方法和步驟。解決問題的過程,就是實現(xiàn)算法的過程。2、算法是程序設計的“靈魂”。瑞士蘇黎世聯(lián)邦工業(yè)大學的NiklausWirth指出:算法+數(shù)據(jù)結構=程序。3、算法獨立于任何具體的程序設計語言,一個算法可以用多種程序設計語言來實現(xiàn)。一、算法的概念1、算法就是解決問題的方法和步驟。解決問題4二、算法的特征有窮性:執(zhí)行有限步之后結束,且每一

步的執(zhí)行時間也都是有限的確定性:每一步都有確切的含義輸入:有零個或多個輸入輸出:至少產(chǎn)生一個輸出可行性:原則上能精確運行,用紙和筆

做有限次運算后即可完成二、算法的特征有窮性:執(zhí)行有限步之后結束,且每一

5三、算法的描述1、用自然語言來描述。2、用流程圖來描述。3、用偽代碼描述算法。三、算法的描述1、用自然語言來描述。61、用自然語言來描述。什么是自然語言?人們?nèi)粘I钪惺褂玫恼Z言

第一步:運羊過河,回來第二步:運菜過河,并運羊回來第三步:運狼過河,回來第四步:運羊過河

通俗易懂,但缺乏直觀性,不簡潔,且易產(chǎn)生歧義。1、用自然語言來描述。什么是自然語言?人們?nèi)粘I钪惺褂玫恼Z7練習一:已知變量x和y中分別存放了數(shù)據(jù),現(xiàn)在要交換其中的數(shù)據(jù)。用自然語言描述算法。練習一:已知變量x和y中分別存放了數(shù)據(jù),現(xiàn)在要交換8算法描述第1步:將x中的數(shù)據(jù)送給變量m,即

x→m;第2步:將y中的數(shù)據(jù)送給變量x,即

y→x;第3步:將m中的數(shù)據(jù)送給變量y,即

m→y。

算法描述第1步:將x中的數(shù)據(jù)送給變量m,即

92、用流程圖來描述

也稱程序框圖,它是算法的一種圖形化表示方法。什么是流程圖?

直觀易懂、邏輯關系清晰,不容易產(chǎn)生歧義。2、用流程圖來描述什么是流程圖?

直觀易懂、邏輯關系清晰,10組成流程圖的流程圖符號開始或結束輸入或輸出處理或運算判斷連接線……開始結束組成流程圖的流程圖符號開始或結束輸入或輸出處理或運算判11第一步:運羊過河,回來第二步:運菜過河,并運羊回來第三步:運狼過河,回來第四步:運羊過河開始結束運羊過河,回來

運菜過河,并運羊回來運狼過河,回來運羊過河例:將過河的算法用流程圖描述出來第一步:運羊過河,回來開始結束運羊過河,回來運菜過河,12練習二:

將交換兩個變量的算法用流程

圖描述。開始結束x→my→xm→y練習二:將交換兩個變量的算法用流程

圖描述。13

例:任意輸入一個實數(shù)到變量X,求下面函數(shù)的Y值:Y=X(X>0)2X(X≤0)例:任意輸入一個實數(shù)到變量X,求下面函數(shù)的Y值:Y=14N結束X大于0?開始輸出Y輸入一個實數(shù)到變量XY判斷框只能有兩個出口Y=xY=2xY=x(x>0)0(x=0)2x(x<0)N結束X大于0?開始輸出Y輸入一個實數(shù)到變量XY判斷框只能有15結束X大于0?開始YNX等于0?YN輸入一個實數(shù)到變量XY=xY=0Y=2X輸出Y結束X大于0?開始YNX等于0?YN輸入一個實數(shù)到變量XY=16分析流程圖結束X>Y?開始YN輸入3個數(shù)到變量X,Y,ZXCYC輸出CZ>C?YNZC分析流程圖結束X>Y?開始YN輸入3個數(shù)到變量X,Y,ZX173、用偽代碼來描述

偽代碼是介于自然語言和計算機語言之間的一種算法描述,在偽代碼描述中,關鍵詞一般用英文單詞.什么是偽代碼?

簡單、易懂,容易修改,且容易轉化為程序語言代碼。3、用偽代碼來描述什么是偽代碼?

簡單、易懂,容易修改,且容18例:用偽代碼描述求解分段函數(shù)

的算法輸入實數(shù)到變量xIF

x大于0

THEN

y=xELSE

y=2xENDIF

打印y例:用偽代碼描述求解分段函數(shù)

的算法輸19

思考算法描述的比較自然語言描述流程圖描述直觀清晰

確定性煩瑣程度是否容易修改通俗易懂√√√√√思考算法描述的比較自然語言描述流201、下面關于算法的描述,正確的是()A.算法不可以用自然語言表示B.算法只能用框圖來表示C.一個算法必須保證它的執(zhí)行步驟是有限的D.一個算法可以有0個或多個輸入,0個或多個輸出2.、下列程序框圖中表示處理、計算的是()A.①B.②C.③D.④3.當我們找到算法之后,可以使用以下方法來描述算法(

)A.自然語言、流程圖、偽代碼B.自然語言、機器語言、偽代碼C.流程圖、機器語言、高級語言D.高級語言、機器語言、偽代碼4.算法與程序的關系(

)A.算法是對程序的描述B.算法決定程序,是算法設計的核心C.算法與程序之間無關系D.程序決定算法,是算法設計的核心5.下列說法錯誤的是(

)A.算法是程序設計的靈魂,由此可見算法的重要地位。B.簡單的說,算法就是解決問題的方法和步驟。C.著名的計算機科學家尼克勞斯指出:“算法+數(shù)據(jù)結構=程序”。D.一個問題的算法只能用一種程序設計語言實現(xiàn)。1、下面關于算法的描述,正確的是()211、下列關于算法說法不正確的是(

)A.算法獨立于任何具體的語言,BASIC算法只能用BASIC語言來實現(xiàn)。B.解決問題的過程就是實現(xiàn)算法的過程。C.算法是程序設計的“靈魂”。D.描述算法可以有多種表達方法。2.下面是關于“剝毛豆”的算法描述:①檢查籃中是否有剩余毛豆;②若無,則算法結束;③若有,將毛豆剝殼,豆粒放入碗中,殼放入垃圾箱;再回到①。該算法的表示方法是(

)A.自然語言B.偽代碼C.流程圖D.程序設計語言3.圖形符號“”在算法流程圖描述中表示(

)。A.處理或運算B.輸入或輸出C.判斷D.開始或結束4.下列敘述中錯誤的是(

)A.程序通常包括指令和數(shù)據(jù)兩大部分B.設計程序時需要考慮的問題是數(shù)據(jù)的存儲和計算的過程C.算法的描述不能用自然語言來表示D.使用計算機解決問題一般要經(jīng)歷分析問題、設計算法、編寫程序、調(diào)試程序等幾個步驟。5.算法與程序的關系(

)A.算法是對程序的描述B.算法決定程序,是程序設計的核心C.算法與程序之間無關系D.程序決定算法,是算法設計的核心1、下列關于算法說法不正確的是(

)22算法描述與設計算法描述與設計23

一個人想用船把狼、羊和一箱菜運送到河對面,但是有兩個條件:

(1)船一次只能運一樣;

(2)當人不在時,狼會吃羊,羊會吃菜。一個人想用船把狼、羊和一箱菜運送到河對面,但是24第一步:運羊過河,回來第二步:運菜過河,并運羊回來第三步:運狼過河,回來第四步:運羊過河將過河的方法描述出來:第一步:運羊過河,回來25

一、算法的概念1、算法就是解決問題的方法和步驟。解決問題的過程,就是實現(xiàn)算法的過程。2、算法是程序設計的“靈魂”。瑞士蘇黎世聯(lián)邦工業(yè)大學的NiklausWirth指出:算法+數(shù)據(jù)結構=程序。3、算法獨立于任何具體的程序設計語言,一個算法可以用多種程序設計語言來實現(xiàn)。一、算法的概念1、算法就是解決問題的方法和步驟。解決問題26二、算法的特征有窮性:執(zhí)行有限步之后結束,且每一

步的執(zhí)行時間也都是有限的確定性:每一步都有確切的含義輸入:有零個或多個輸入輸出:至少產(chǎn)生一個輸出可行性:原則上能精確運行,用紙和筆

做有限次運算后即可完成二、算法的特征有窮性:執(zhí)行有限步之后結束,且每一

27三、算法的描述1、用自然語言來描述。2、用流程圖來描述。3、用偽代碼描述算法。三、算法的描述1、用自然語言來描述。281、用自然語言來描述。什么是自然語言?人們?nèi)粘I钪惺褂玫恼Z言

第一步:運羊過河,回來第二步:運菜過河,并運羊回來第三步:運狼過河,回來第四步:運羊過河

通俗易懂,但缺乏直觀性,不簡潔,且易產(chǎn)生歧義。1、用自然語言來描述。什么是自然語言?人們?nèi)粘I钪惺褂玫恼Z29練習一:已知變量x和y中分別存放了數(shù)據(jù),現(xiàn)在要交換其中的數(shù)據(jù)。用自然語言描述算法。練習一:已知變量x和y中分別存放了數(shù)據(jù),現(xiàn)在要交換30算法描述第1步:將x中的數(shù)據(jù)送給變量m,即

x→m;第2步:將y中的數(shù)據(jù)送給變量x,即

y→x;第3步:將m中的數(shù)據(jù)送給變量y,即

m→y。

算法描述第1步:將x中的數(shù)據(jù)送給變量m,即

312、用流程圖來描述

也稱程序框圖,它是算法的一種圖形化表示方法。什么是流程圖?

直觀易懂、邏輯關系清晰,不容易產(chǎn)生歧義。2、用流程圖來描述什么是流程圖?

直觀易懂、邏輯關系清晰,32組成流程圖的流程圖符號開始或結束輸入或輸出處理或運算判斷連接線……開始結束組成流程圖的流程圖符號開始或結束輸入或輸出處理或運算判33第一步:運羊過河,回來第二步:運菜過河,并運羊回來第三步:運狼過河,回來第四步:運羊過河開始結束運羊過河,回來

運菜過河,并運羊回來運狼過河,回來運羊過河例:將過河的算法用流程圖描述出來第一步:運羊過河,回來開始結束運羊過河,回來運菜過河,34練習二:

將交換兩個變量的算法用流程

圖描述。開始結束x→my→xm→y練習二:將交換兩個變量的算法用流程

圖描述。35

例:任意輸入一個實數(shù)到變量X,求下面函數(shù)的Y值:Y=X(X>0)2X(X≤0)例:任意輸入一個實數(shù)到變量X,求下面函數(shù)的Y值:Y=36N結束X大于0?開始輸出Y輸入一個實數(shù)到變量XY判斷框只能有兩個出口Y=xY=2xY=x(x>0)0(x=0)2x(x<0)N結束X大于0?開始輸出Y輸入一個實數(shù)到變量XY判斷框只能有37結束X大于0?開始YNX等于0?YN輸入一個實數(shù)到變量XY=xY=0Y=2X輸出Y結束X大于0?開始YNX等于0?YN輸入一個實數(shù)到變量XY=38分析流程圖結束X>Y?開始YN輸入3個數(shù)到變量X,Y,ZXCYC輸出CZ>C?YNZC分析流程圖結束X>Y?開始YN輸入3個數(shù)到變量X,Y,ZX393、用偽代碼來描述

偽代碼是介于自然語言和計算機語言之間的一種算法描述,在偽代碼描述中,關鍵詞一般用英文單詞.什么是偽代碼?

簡單、易懂,容易修改,且容易轉化為程序語言代碼。3、用偽代碼來描述什么是偽代碼?

簡單、易懂,容易修改,且容40例:用偽代碼描述求解分段函數(shù)

的算法輸入實數(shù)到變量xIF

x大于0

THEN

y=xELSE

y=2xENDIF

打印y例:用偽代碼描述求解分段函數(shù)

的算法輸41

思考算法描述的比較自然語言描述流程圖描述直觀清晰

確定性煩瑣程度是否容易修改通俗易懂√√√√√思考算法描述的比較自然語言描述流421、下面關于算法的描述,正確的是()A.算法不可以用自然語言表示B.算法只能用框圖來表示C.一個算法必須保證它的執(zhí)行步驟是有限的D.一個算法可以有0個或多個輸入,0個或多個輸出2.、下列程序框圖中表示處理、計算的是()A.①B.②C.③D.④3.當我們找到算法之后,可以使用以下方法來描述算法(

)A.自然語言、流程圖、偽代碼B.自然語言、機器語言、偽代碼C.流程圖、機器語言、高級語言D.高級語言、機器語言、偽代碼4.算法與程序的關系(

)A.算法是對程序的描述B.算法決定程序,是算法設計的核心C.算法與程序之間無關系D.程序決定算法,是算法設計的核心5.下列說法錯誤的是(

)A.算法是程序設計的靈魂,由此可見算法的重要地位。B.簡單的說,算法就是解決問題

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論