目录
循环结构就是程序中控制某条或某些指令重复执行的结构。在Python中构造循环结构有两种做法,一种是for-in
循环,一种是while
循环。
for-in循环
1.明确知道循环的次数
例如计算1到100的和。 被for-in
循环控制的语句块也是通过缩进的方式来确定的,这一点跟分支结构完全相同,
>>> total=0
>>> for x in range(1,101):
total+=x
>>> print(total)
5050
>>>
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之间的偶数求和。
(1)
>>> total=0
>>> for x in range(100,0,-2):
total+=x
>>> print(total)
2550
(2)
>>> total =0
>>> for x in range(2,101,2):
total+=x
>>> print(total)
2550
while循环
如果要构造不知道具体循环次数的循环结构,我们推荐使用while
循环。
while
循环通过一个能够产生或转换出bool
值的表达式来控制循环,表达式的值为True
则继续循环;表达式的值为False
则结束循环。
下面我们通过一个“猜数字”的小游戏来看看如何使用while
循环。猜数字游戏的规则是:计算机出一个1到100之间的随机数,玩家输入自己猜的数字,计算机给出对应的提示信息(大一点、小一点或猜对了),如果玩家猜中了数字,计算机提示用户一共猜了多少次,游戏结束,否则游戏继续。
>>> import random
>>> answer=random.randint(1,100)
>>> count=0
>>> while True:
count+=1
number=int(input("请输入:"))
if number<answer:
print("大一点")
elif number >answer:
print("小一点")
else:
print("恭喜猜对")
break
请输入:12
大一点
请输入:15
大一点
请输入:35
小一点
请输入:24
大一点
请输入:28
小一点
请输入:27
小一点
请输入:26
恭喜猜对
>>> print(count)
7
break和continue
上面的代码中使用while True
构造了一个条件恒成立的循环,也就意味着如果不做特殊处理,循环是不会结束的,这也就是常说的“死循环”。
为了在用户猜中数字时能够退出循环结构,我们使用了break
关键字,它的作用是提前结束循环。
需要注意的是,break
只能终止它所在的那个循环,这一点在使用嵌套循环结构时需要引起注意,下面的例子我们会讲到什么是嵌套的循环结构。
除了break
之外,还有另一个关键字是continue
,它可以用来放弃本次循环后续的代码直接让循环进入下一轮。
嵌套的循环结构
和分支结构一样,循环结构也是可以嵌套的,也就是说在循环中还可以构造循环结构。下面的例子演示了如何通过嵌套的循环来输出一个
乘法口诀表(九九表)。
>>>for i in range(1,10):
for j in range(1,i+1):
print(f'{i}*{j}={i*j}',end='\t')
print()
1*1=1
2*1=2 2*2=4
3*1=3 3*2=6 3*3=9
4*1=4 4*2=8 4*3=12 4*4=16
5*1=5 5*2=10 5*3=15 5*4=20 5*5=25
6*1=6 6*2=12 6*3=18 6*4=24 6*5=30 6*6=36
7*1=7 7*2=14 7*3=21 7*4=28 7*5=35 7*6=42 7*7=49
8*1=8 8*2=16 8*3=24 8*4=32 8*5=40 8*6=48 8*7=56 8*8=64
9*1=9 9*2=18 9*3=27 9*4=36 9*5=45 9*6=54 9*7=63 9*8=72 9*9=81
>>>
在上面的代码中,外层循环用来控制一共会产生9行的输出,而内层循环用来控制每一行会输出多少列。内层循环中的输出就是九九表一行中的所有列,所以在内层循环完成时,有一个print()
来实现换行输出的效果。
例子1:输入一个正整数判断它是不是素数。
>>> num =int(input("输入一个数字:"))
输入一个数字:29
>>> end =int(num**0.5)
>>> 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(f'{num}是素数')
else:
print(f'{num}不是素数')
29是素数
例子2:输入两个正整数,计算它们的最大公约数和最小公倍数
>>> def main():
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
>>> if __name__ == '__main__':
main()
x = 12
y = 35
12和35的最大公约数是1
12和35的最小公倍数是420
>>>
课程链接:https://github.com/jackfrued/Python-Core-50-Courses/blob/master