python之循環結構


循環結構

應用場景

我們在寫程序的時候,一定會遇到需要重復執行某條或某些指令的場景。例如用程序控制機器人踢足球,如果機器人持球而且還沒有進入射門范圍,那么我們就要一直發出讓機器人向球門方向移動的指令。在這個場景中,讓機器人向球門方向移動就是一個需要重復的動作,當然這里還會用到上一課講的分支結構來判斷機器人是否持球以及是否進入射門范圍。再舉一個簡單的例子,如果要實現每隔1秒中在屏幕上打印一次“hello, world”並持續打印一個小時,我們肯定不能夠直接把print('hello, world')這句代碼寫3600遍,這里同樣需要循環結構。

循環結構就是程序中控制某條或某些指令重復執行的結構。在Python中構造循環結構有兩種做法,一種是for-in循環,一種是while循環。

for-in循環

如果明確的知道循環執行的次數或者要對一個容器進行迭代(后面會講到),那么我們推薦使用for-in循環,例如下面代碼中計算1~100求和的結果($\displaystyle \sum \limits_{n=1}^{100}n$)。

"""
用for循環實現1~100求和

Version: 0.1
Author: 田田雲逸
"""

sum = 0
for x in range(101):
   sum += x
print(sum)

需要說明的是上面代碼中的range(1, 101)可以用來構造一個從1到100的范圍,當我們把這樣一個范圍放到for-in循環中,就可以通過前面的循環變量x依次取出從1到100的整數。當然,range的用法非常靈活,下面給出了一個例子:

  • range(101):可以用來產生0到100范圍的整數,需要注意的是取不到101。

  • range(1, 101):可以用來產生1到100范圍的整數,相當於前面是閉區間后面是開區間。

  • range(1, 101, 2):可以用來產生1到100的奇數,其中2是步長,即每次數值遞增的值。

  • range(100, 0, -2):可以用來產生100到1的偶數,其中-2是步長,即每次數字遞減的值。

知道了這一點,我們可以用下面的代碼來實現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循環。while循環通過一個能夠產生或轉換出bool值的表達式來控制循環,表達式的值為True則繼續循環;表達式的值為False則結束循環。

下面我們通過一個“猜數字”的小游戲來看看如何使用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()


免責聲明!

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



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