04 迴圈結構

2021-10-02 16:44:35 字數 4402 閱讀 4674

如果在程式中我們需要重複的執行某條或某些指令,例如用程式控制機械人踢足球,如果機械人持球而且還沒有進入射門範圍,那麼我們就要一直發出讓機械人向球門方向奔跑的指令。當然你可能已經注意到了,剛才的描述中不僅僅有需要重複的動作,還需要用到上一章講的分支結構。再舉乙個簡單的例子,我們要實現乙個每隔1秒中在螢幕上列印一次"hello, world"並持續列印乙個小時的程式,我們肯定不能夠直接把print('hello, world')這句**寫3600遍,如果真的要這樣做,那麼程式設計的工作就太無聊乏味了。因此,我們還需要了解一下迴圈結構,有了迴圈結構我們就可以輕鬆的控制某件事或者某些事重複、重複、再重複的去執行。

在python中構造迴圈結構有兩種做法,一種是for-in迴圈,一種是while迴圈。

如果明確的知道迴圈執行的次數或者要對乙個容器進行迭代(後面會講到),那麼我們推薦使用for-in迴圈,例如下面**中計算1~100求和的結果(∑n=

1100

n\displaystyle \sum \limits_^n

n=1∑10

0​n)。

"""

用for迴圈實現1~100求和

version: 0.1

author: 駱昊

"""sum = 0

for x in range(101):

sum += x

print(sum)

需要說明的是上面**中的range(101)可以用來構造乙個從0到100的取值範圍,這樣就可以構造出乙個整數的序列並用於迴圈中,例如:

知道了這一點,我們可以用下面的**來實現1~100之間的偶數求和。

"""

用for迴圈實現1~100之間的偶數求和

version: 0.1

author: 駱昊

"""sum = 0

for x in range(2, 101, 2):

sum += x

print(sum)

也可以通過在迴圈中使用分支結構的方式來實現相同的功能,**如下所示。

"""

用for迴圈實現1~100之間的偶數求和

version: 0.1

author: 駱昊

"""sum = 0

for x in range(1, 101):

if x % 2 == 0:

sum += x

print(sum)

如果要構造不知道具體迴圈次數的迴圈結構,我們推薦使用while迴圈。while迴圈通過乙個能夠產生或轉換出bool值的表示式來控制迴圈,表示式的值為true迴圈繼續,表示式的值為false迴圈結束。下面我們通過乙個「猜數字」的小遊戲(計算機出乙個1~100之間的隨機數,人輸入自己猜的數字,計算機給出對應的提示資訊,直到人猜出計算機出的數字)來看看如何使用while迴圈。

"""

猜數字遊戲

計算機出乙個1~100之間的隨機數由人來猜

計算機根據人猜的數字分別給出提示大一點/小一點/猜對了

version: 0.1

author: 駱昊

"""import random

answer = random.randint(1, 100)

counter = 0

while true:

counter += 1

number = int(input('請輸入: '))

if number < answer:

print('大一點')

elif number > answer:

print('小一點')

else:

print('恭喜你猜對了!')

break

print('你總共猜了%d次' % counter)

if counter > 7:

print('你的智商餘額明顯不足')

上面的**中使用了break關鍵字來提前終止迴圈,需要注意的是break只能終止它所在的那個迴圈,這一點在使用巢狀的迴圈結構(下面會講到)需要引起注意。除了break之外,還有另乙個關鍵字是continue,它可以用來放棄本次迴圈後續的**直接讓迴圈進入下一輪。

和分支結構一樣,迴圈結構也是可以巢狀的,也就是說在迴圈中還可以構造迴圈結構。下面的例子演示了如何通過巢狀的迴圈來輸出乙個九九乘法表。

"""

輸出乘法口訣表(九九表)

version: 0.1

author: 駱昊

"""for i in range(1, 10):

for j in range(1, i + 1):

print('%d*%d=%d' % (i, j, i * j), end='\t')

print()

練習1:輸入乙個正整數判斷是不是素數。
提示:素數指的是只能被1和自身整除的大於1的整數。

"""

輸入乙個正整數判斷它是不是素數

version: 0.1

author: 駱昊

date: 2018-03-01

"""from math import sqrt

num = int(input('請輸入乙個正整數: '))

end = int(sqrt(num))

is_prime = true

for x in range(2, end + 1):

if num % x == 0:

is_prime = false

break

if is_prime and num != 1:

print('%d是素數' % num)

else:

print('%d不是素數' % num)

練習2:輸入兩個正整數,計算它們的最大公約數和最小公倍數。
"""

輸入兩個正整數計算它們的最大公約數和最小公倍數

version: 0.1

author: 駱昊

date: 2018-03-01

"""x = int(input('x = '))

y = int(input('y = '))

# 如果x大於y就交換x和y的值

if x > y:

# 通過下面的操作將y的值賦給x, 將x的值賦給y

x, y = y, x

# 從兩個數中較的數開始做遞減的迴圈

for factor in range(x, 0, -1):

if x % factor == 0 and y % factor == 0:

print('%d和%d的最大公約數是%d' % (x, y, factor))

print('%d和%d的最小公倍數是%d' % (x, y, x * y // factor))

break

練習3:列印如下所示的三角形圖案。
*

*****

****

*****

*

*****

****

*****

*

********

*******

*********

"""

列印三角形圖案

version: 0.1

author: 駱昊

"""row = int(input('請輸入行數: '))

for i in range(row):

for _ in range(i + 1):

print('*', end='')

print()

for i in range(row):

for j in range(row):

if j < row - i - 1:

print(' ', end='')

else:

print('*', end='')

print()

for i in range(row):

for _ in range(row - i - 1):

print(' ', end='')

for _ in range(2 * i + 1):

print('*', end='')

print()

04迴圈結構

a.迴圈開始 b.迴圈計數 自增和自減 目的是到一定條件下退出 c.迴圈條件判斷 若為真,則繼續進行迴圈,若為假,則跳出迴圈 注意 不考慮迴圈判斷條件始終為真,在迴圈裡面通過break跳出迴圈的這一種情況 2.1迴圈的分類 while迴圈 語法 while 迴圈判斷條件 通常有一條語句是用來進行迴圈...

04 迴圈結構

我們在寫程式的時候,一定會遇到需要重複執行某條或某些指令的場景。例如用程式控制機械人踢足球,如果機械人持球而且還沒有進入射門範圍,那麼我們就要一直發出讓機械人向球門方向移動的指令。在這個場景中,讓機械人向球門方向移動就是乙個需要重複的動作,當然這裡還會用到上一課講的分支結構來判斷機械人是否持球以及是...

Day04 迴圈結構

如果在程式中我們需要重複的執行某條或某些指令,例如用程式控制機械人踢足球,如果機械人持球而且還沒有進入射門範圍,那麼我們就要一直發出讓機械人向球門方向奔跑的指令。當然你可能已經注意到了,剛才的描述中其實不僅僅有需要重複的動作,還有我們上乙個章節講到的分支結構。再舉乙個簡單的例子,比如在我們的程式中要...