Python-100-Days: Day04 循环结构

发布于:2024-05-06 ⋅ 阅读:(32) ⋅ 点赞:(0)

应用场景

写程序会遇到重复执行或者特定的指令的场景。这些场景通常是可以使用循环结构进行处理的。

循环结构就是程序中控制某条或某些指令重复执行的结构。在Python中构造循环结构有两种做法,一种是for-in循环,一种是while循环。

for-in循环

若明确循环执行的次数或对某个特定的容器进行迭代。推荐使用for-in循环。

ep: 计算1-100求和的summary。

"""
用for循环实现1~100求和

Version: 0.1
Author: Maxwell
"""

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

 

Note: range(1,101) 可以用来构造一个从1到100的范围,可以通过前面的循环变量x依次取出从1到100的整数。

range(101): 产生0到100范围的整数,需要注意无法取到101.

range(1,101) :产生1到100范围的整数,相当于闭区间后面是开区间。

range(1,101,2): 产生1到100的奇数,2是步长,即每次数值递增的值。

range(100,0,-2): 产生100到1的偶数,-2为步长,即每次数字递减的值。

"""
用for循环实现1~100求和

Version: 0.1
Author: Maxwell
"""

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

 

也可通过循环中使用分支结构的方式来实现相同的功能,代码如下所示。

"""
用for循环实现1~100之间的偶数求和

Version: 0.1
Author: Maxwell
"""

sum = 0
for x in range(1, 101):
    if x % 2 == 0:
        sum += x
print(sum)

 

while循环

若构造未知循环次数的循环结构,推荐使用while循环,它通过产生或转换出bool值的表达式进行循环控制,为True时,进行循环。为False时则结束循环。

通过一个“猜数字”的小游戏来看看如何使用while循环。猜数字游戏的规则是:计算机出一个1到100之间的随机数,玩家输入自己猜的数字,计算机给出对应的提示信息(大一点、小一点或猜对了),如果玩家猜中了数字,计算机提示用户一共猜了多少次,游戏结束,否则游戏继续。

"""
猜数字游戏

Version: 0.1
Author: Maxwell
"""
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只能终止它所在的那个循环。

和分支结构一样,循环结构也是可以嵌套的,也就是说在循环中还可以构造循环结构。下面的例子演示了如何通过嵌套的循环来输出一个九九乘法表。

"""
输出乘法口诀表(九九表)

Version: 0.1
Author: Maxwell
"""

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: Maxwell
Date: 2024-04-28
"""

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: Maxwell
Date: 2024-04-28
"""

x = int(input('x = '))
y = int(input('y = '))
if 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: Maxwell
Date: 2024-04-28
"""

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()