PYTHON程序設(shè)計 課件 【ch03】控制結(jié)構(gòu)_第1頁
PYTHON程序設(shè)計 課件 【ch03】控制結(jié)構(gòu)_第2頁
PYTHON程序設(shè)計 課件 【ch03】控制結(jié)構(gòu)_第3頁
PYTHON程序設(shè)計 課件 【ch03】控制結(jié)構(gòu)_第4頁
PYTHON程序設(shè)計 課件 【ch03】控制結(jié)構(gòu)_第5頁
已閱讀5頁,還剩29頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

控制結(jié)構(gòu)“計算機(jī)類精品系列教材Python程序設(shè)計第三章01順序結(jié)構(gòu)一、順序結(jié)構(gòu)01賦值語句(1)直接賦值直接賦值為賦值語句的基礎(chǔ)形式。其語句格式如下:變量名=變量值(2)元組賦值元組賦值的格式如下:變量1,變量2,…=值1,值2,…(3)序列賦值把字符串序列中的字符分別賦值給變量。右側(cè)的元素的數(shù)量和左側(cè)的變量的數(shù)量必須相等,否則會報錯。(4)多目標(biāo)賦值在Python中可以同時為多個變量賦值。其語句格式為:變量1=變量2=…=值。(5)復(fù)合賦值。復(fù)合賦值也叫增強(qiáng)賦值,該類型的賦值方法中包含的運(yùn)算符包括:+=、-=、*=、=等。一、順序結(jié)構(gòu)02空語句在Python中,pass表示空語句。該語句不執(zhí)行命令,只是一個占位符,一是為了保證格式完整,二是為了保證語義完整,一般在if條件語句、for-in循環(huán)語句或定義函數(shù)的語句中配合使用。例如,用for循環(huán)輸出1~10(不包括10)之間的偶數(shù),其中奇數(shù)就用pass語句占個位置。代碼如下:一、順序結(jié)構(gòu)03順序語句順序語句是最簡單的結(jié)構(gòu)語句,按照語句的先后順序執(zhí)行,自上而下,處理好上一條語句的結(jié)果后才會繼續(xù)執(zhí)行下一條語句。在Python中,一個語句的結(jié)束是以換行為標(biāo)志的。例如,用順序語句計算圓的面積和周長:02分支結(jié)構(gòu)二、分支結(jié)構(gòu)01單分支結(jié)構(gòu)單分支結(jié)構(gòu)是分支結(jié)構(gòu)中最簡單的形式,當(dāng)且僅當(dāng)條件語句被滿足時,語句塊才會被執(zhí)行,否則跳過語句塊,執(zhí)行后面的語句。單分支的語法結(jié)構(gòu)為:if表達(dá)式:語句塊一個if語句包含以下5個要素。(1)關(guān)鍵詞if。(2)條件表達(dá)式。(3)英文冒號(:)。(4)縮進(jìn)。(5)語句塊。其流程圖如圖3-1所示。二、分支結(jié)構(gòu)01單分支結(jié)構(gòu)例如:比較兩個數(shù),取較大值。因為a>b,所以第2個if語句什么都不會輸出。二、分支結(jié)構(gòu)01單分支結(jié)構(gòu)注意:(1)關(guān)鍵字if后面有空格,沒有空格程序會報錯。(2)條件表達(dá)式后面的冒號必須是英文冒號,若使用中文冒號,則程序會報錯,提示的錯誤為SyntaxError:invalidcharacter(無效字符)。(3)代碼塊前面有縮進(jìn),縮進(jìn)在Python中是一種語法格式,必須嚴(yán)格執(zhí)行。(4)語句塊可以是一條語句,也可以是多條語句。如果語句塊中只有一條語句,則可以將其表示為如下形式:if

a<b:max=b但是這會影響程序的可讀性,不建議使用。二、分支結(jié)構(gòu)02雙分支結(jié)構(gòu)雙分支結(jié)構(gòu)實現(xiàn)的是二選一的功能,即非此即彼。在Python中,通過if…else…語句實現(xiàn)雙分支結(jié)構(gòu)。在雙分支結(jié)構(gòu)中,根據(jù)判斷條件表達(dá)式的真假執(zhí)行不同的語句,如果條件表達(dá)式的值是True,則執(zhí)行if下的語句塊1;如果條件表達(dá)式的值是False,則執(zhí)行else下的語句塊2。雙分支的語法結(jié)構(gòu)為:if表達(dá)式:語句塊1else:語句塊2其流程圖如圖3-2所示。二、分支結(jié)構(gòu)03多分支結(jié)構(gòu)當(dāng)判斷情況較多時,在Python中可以使用if…elif…else…多分支結(jié)構(gòu),elif表示否則如果,也是判斷語句,但是它不能單獨(dú)使用,必須和if一起使用。if語句的表達(dá)式不成立時,才會執(zhí)行elif后面的表達(dá)式,if與else中間可以有多個elif插入,只有當(dāng)if和elif后面的表達(dá)式都不成立時,才會執(zhí)行else語句。多分支的語法結(jié)構(gòu)可以表示為:if

表達(dá)式1:語句塊1elif

表達(dá)式2:語句塊2····else:語句塊n二、分支結(jié)構(gòu)03多分支結(jié)構(gòu)多分支結(jié)構(gòu)和雙分支結(jié)構(gòu)一樣,表達(dá)式可以是布爾值、變量、關(guān)系表達(dá)式和邏輯表達(dá)式。其流程圖如圖3-3所示。二、分支結(jié)構(gòu)03多分支結(jié)構(gòu)現(xiàn)在利用多分支結(jié)構(gòu)根據(jù)以下要求編寫程序:根據(jù)輸入的考試分?jǐn)?shù)分為優(yōu)秀、良好、合格、差4個等級,考試分?jǐn)?shù)為0~100分。分?jǐn)?shù)在90~100分之間(包括90分和100分)為優(yōu)秀,分?jǐn)?shù)在70~90分之間(包括70分)為良好,分?jǐn)?shù)在60~70分之間(包括60分)為合格,分?jǐn)?shù)低于60分為差。03循環(huán)結(jié)構(gòu)三、循環(huán)結(jié)構(gòu)01常用的循環(huán)算法1.窮舉法窮舉法是一種簡單的算法,也叫作枚舉法,即通過遍歷條件范圍,逐個試驗來找出答案,常用于解決“是否存在”和“有幾種可能”的問題。需要注意的是,問題中所涉及的情況應(yīng)一一列舉,不能遺漏,不能重復(fù)。理論上,窮舉法可以解決可計算領(lǐng)域中的各種問題。尤其是在計算機(jī)速度非??斓慕裉欤F舉法的應(yīng)用領(lǐng)域非常廣闊。在實際應(yīng)用中,通常要解決的問題規(guī)模不大,采用窮舉法的運(yùn)算速度是可以接受的。此時,設(shè)計一個更高效的算法不值得。利用窮舉法解決問題的過程如下。(1)分析題目,確定答案的數(shù)據(jù)類型和大致范圍。(2)遍歷范圍內(nèi)的所有情況。(3)對遍歷的情況一一驗證,輸出所有符合條件的答案。三、循環(huán)結(jié)構(gòu)01常用的循環(huán)算法2.迭代法迭代法就是不斷用變量的舊值去推變量的新值的過程,是計算機(jī)語言中解決問題的一種基本方法,一般用于數(shù)值計算,又稱輾轉(zhuǎn)法。利用迭代法解決問題的步驟如下。(1)確定迭代變量:在利用迭代法解決的問題中,根據(jù)舊值來不斷地更新的變量就是迭代變量。(2)建立迭代關(guān)系式:根據(jù)變量的前一個值與后一個值之間的關(guān)系,建立關(guān)系式。(3)對迭代過程進(jìn)行控制;何時結(jié)束迭代。當(dāng)?shù)螖?shù)確定時,可以構(gòu)建固定的循環(huán)次數(shù);當(dāng)?shù)螖?shù)不確定時,需要進(jìn)一步分析結(jié)束迭代的條件。三、循環(huán)結(jié)構(gòu)01常用的循環(huán)算法迭代法的優(yōu)點(diǎn):(1)迭代法的效率高,運(yùn)行時間只因循環(huán)次數(shù)增加而增加。(2)沒有額外開銷,空間上也沒有增加。迭代法的缺點(diǎn):(1)不容易理解。(2)代碼不如遞歸法的代碼簡潔。(3)解決復(fù)雜問題時困難。三、循環(huán)結(jié)構(gòu)01常用的循環(huán)算法3.遞歸法遞歸法就是子程序(或函數(shù))直接調(diào)用自己或通過一系列調(diào)用語句間接調(diào)用自己,是一種描述問題和解決問題的基本方法。遞歸法常用來解決結(jié)構(gòu)相似的問題。所謂結(jié)構(gòu)相似,是指構(gòu)成原問題的子問題與原問題在結(jié)構(gòu)上相似,可以用類似的方法解決。具體的整個問題的解決可以分為兩部分:第一部分是一些特殊情況,有直接的解法;第二部分與原問題相似,但比原問題的規(guī)模小,并且依賴第一部分的結(jié)果。三、循環(huán)結(jié)構(gòu)01常用的循環(huán)算法實際上,遞歸法是把一個不能或不好解決的大問題轉(zhuǎn)換成一個或幾個小問題,再把這些小問題進(jìn)一步分解成更小的小問題,直至每個小問題都可以直接解決。因此,遞歸法有以下兩個基本要素。(1)邊界條件:確定遞歸到何時終止,也稱為遞歸出口。(2)遞歸模式:大問題是如何分解為小問題的,也稱為遞歸體。遞歸函數(shù)只有具備了這兩個要素,才能在有限次計算后得出結(jié)果。三、循環(huán)結(jié)構(gòu)01常用的循環(huán)算法遞歸法的優(yōu)點(diǎn):(1)大問題化為小問題,可以極大地減少代碼量。(2)用有限的語句來定義對象的無限集合。(3)代碼更簡潔清晰,可讀性更好。遞歸法的缺點(diǎn):實際上遞歸法不斷地深層調(diào)用函數(shù),直到函數(shù)有返回值才會逐層地返回,遞歸法是用棧機(jī)制實現(xiàn)的,每深入一層,都要占用一塊棧數(shù)據(jù)區(qū)域。因此,遞歸法涉及運(yùn)行時的堆棧開銷(參數(shù)必須壓入堆棧保存,直到該層函數(shù)調(diào)用返回為止),所以有可能出現(xiàn)堆棧溢出的錯誤。遞歸和迭代的關(guān)系:遞歸中一定有迭代,但是迭代中不一定有遞歸,大部分可以相互轉(zhuǎn)換。相對來說,可以用迭代就不用遞歸,因為遞歸不斷調(diào)用函數(shù),浪費(fèi)空間。三、循環(huán)結(jié)構(gòu)02for循環(huán)循環(huán)語句是Python中執(zhí)行迭代和窮舉法需要使用的語句。Python包含兩個循環(huán)語句,一個是for循環(huán)語句,一個是while循環(huán)語句。for循環(huán)常常與in搭配組成for…in結(jié)構(gòu),該結(jié)構(gòu)通常用于枚舉和遍歷,循環(huán)內(nèi)的語句段會將對象的每一個元素都遍歷一次。其語法格式如下:for

變量

in

對象:循環(huán)體其中,對象是需要遍歷的容器。注意:for循環(huán)語句中的英文冒號一定不可以省略。循環(huán)體前面是有縮進(jìn)的。for循環(huán)的流程圖如圖3-4所示。三、循環(huán)結(jié)構(gòu)02

for循環(huán)for循環(huán)語句的執(zhí)行過程:首先,判斷容器中是否有元素,如果有則從容器中取出第一個元素并執(zhí)行循環(huán)體,如果沒有則退出循環(huán);之后,判斷是否已經(jīng)遍歷完容器中的所有元素,如果沒有遍歷完,則繼續(xù)取出一個元素并執(zhí)行循環(huán)體,直到遍歷完容器中的所有元素;最后,遍歷完所有元素后,for循環(huán)自動退出,并繼續(xù)執(zhí)行下面的語句。for循環(huán)經(jīng)常跟range()函數(shù)一起用。range()函數(shù)是Python的一個內(nèi)置函數(shù),可以生成一系列整數(shù)。該函數(shù)的語法格式如下:range(start,end,step)三、循環(huán)結(jié)構(gòu)02

for循環(huán)其中參數(shù)的含義如下:start是計數(shù)的開始值,其默認(rèn)值為0,如果開始值為0的話,可以省略不寫。end是計數(shù)的結(jié)束值,但是不包括該值,如range(5)代表的計數(shù)范圍是0~4。step是計數(shù)的步長,也就是兩個數(shù)之間的間隔,可以省略不寫。如果省略,則其默認(rèn)步長為1,如range(1,11,2)生成1、3、5、7、9這些整數(shù),range(11,1,-2)生成11、9、7、5、3這些整數(shù)。三、循環(huán)結(jié)構(gòu)03while循環(huán)while循環(huán)在滿足特定條件時才執(zhí)行循環(huán)體,可用于處理一些需要重復(fù)處理的相同任務(wù)。其語法格式如下:while條件表達(dá)式:循環(huán)體注意:while循環(huán)語句中的冒號一定不要省略。循環(huán)體前面是有縮進(jìn)的。不要忘記添加循環(huán)的終止條件,否則會形成死循環(huán)。while循環(huán)語句執(zhí)行的具體流程:首先判斷條件表達(dá)式的值,若其值為True,則執(zhí)行循環(huán)體中的語句。當(dāng)執(zhí)行完畢后,再次判斷條件表達(dá)式的值是否為True,若仍為True,則繼續(xù)執(zhí)行循環(huán)體,直到條件表達(dá)式的值為False才會退出循環(huán)。while循環(huán)的流程圖如圖3-5所示。04嵌套循環(huán)四、嵌套循環(huán)Python是允許在一個循環(huán)里面嵌入另一個循環(huán)的,這種循環(huán)里面嵌入另一個循環(huán)的語句被稱為循環(huán)的嵌套。for循環(huán)和while循環(huán)都可以進(jìn)行循環(huán)嵌套,位于外層的循環(huán)結(jié)構(gòu)被稱為外循環(huán),位于內(nèi)層的循環(huán)結(jié)構(gòu)被稱為內(nèi)循環(huán)。對于外層循環(huán)的每次迭代,內(nèi)層循環(huán)都要完成它的所有迭代。while循環(huán)中嵌套while循環(huán)的格式如下:while條件語句1:循環(huán)體1其他語句while條件語句2:循環(huán)體2循環(huán)體1其他語句四、嵌套循環(huán)for循環(huán)中嵌套for循環(huán)的格式如下:for

變量1in

對象1:循環(huán)體1其他語句for變量2in對象2:循環(huán)體2循環(huán)體1其他語句while循環(huán)中可以嵌套for循環(huán),for循環(huán)中也可以嵌套while循環(huán)。四、嵌套循環(huán)上述語句中的“循環(huán)體1其他語句”可以根據(jù)實際情況添加或省略。這里以for循環(huán)中嵌套for循環(huán)為例,做一個九九乘法表。代碼如下:運(yùn)行結(jié)果如圖3-6所示。05break語句、continue語句和else子句五、break語、continue語句和else子句01break語句break語句的功能是在循環(huán)體中強(qiáng)制退出當(dāng)前循環(huán),用于終止循環(huán)語句的執(zhí)行。該語句必須在循環(huán)體內(nèi)使用,在循環(huán)體外使用會報錯。break語句通常和if語句一起使用,表示在指定條件下強(qiáng)制退出循環(huán)。break語句用于for循環(huán)和while循環(huán)中,如果用于嵌套循環(huán),則會強(qiáng)制退出它所在的那一層循環(huán)然后執(zhí)行后面的代碼。在while循環(huán)中使用break語句的格式如下:while條件表達(dá)式1:循環(huán)體if條件表達(dá)式2:break在for循環(huán)中使用break語句的格式如下:for變量

in

對象:if條件表達(dá)式:break五、break語句、continue語句和else子句02continue語句continue語句的功能是結(jié)束本次循環(huán),進(jìn)入下一次循環(huán),而不退出循環(huán)。continue語句同樣必須在循環(huán)體內(nèi)使用,在循環(huán)體外使用會報錯。continue語句通常也和if語句一起使用,表示在滿足某個條件后結(jié)束本次循環(huán)(不書行當(dāng)前循環(huán)后面的語句),然后進(jìn)行下一次循環(huán)。continue語句在while循環(huán)和for循環(huán)內(nèi)的使用和break語句類似。例如,在while往環(huán)中使用continue語句的格式如下:while條件語句1;循環(huán)體if條件語句2:continue五、break語句、continue語句和else子句02conti

溫馨提示

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

評論

0/150

提交評論