- 应用场景
- for-in循环
- while循环
- 练习
- 练习1:输入一个正整数判断是不是素数。
- 练习2:输入两个正整数,计算它们的最大公约数和最小公倍数。
- 练习3:打印如下所示的三角形图案。
如果要实现每隔1秒中在屏幕上打印一次“hello, world”并持续打印一个小时,我们肯定不能够直接把print('hello, world')这句代码写3600遍,这里同样需要循环结构。
循环结构就是程序中控制某条或某些指令重复执行的结构。在Python中构造循环结构有两种做法,一种是for-in循环,一种是while循环。
for-in循环如果明确的知道循环执行的次数或者要对一个容器进行迭代,那么我们推荐使用for-in循环,例如下面代码中计算1~100求和的结果( ∑ n = 1 100 n displaystyle sum limits_{n=1}^{100}n n=1∑100n)。
"""
用for循环实现1~100求和
"""
sum = 0
for x in range(101):
sum += x
print(sum)
"""
输出:5050
"""
上面代码中的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之间的偶数求和
"""
sum = 0
for x in range(2,101,2):
sum += x
print(sum)
"""
输出:2550
"""
也可以通过在循环中使用分支结构的方式来实现相同的功能,代码如下所示。
"""
用for循环实现1~100之间的偶数求和
"""
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之间的随机数,玩家输入自己猜的数字,计算机给出对应的提示信息(大一点、小一点或猜对了),如果玩家猜中了数字,计算机提示用户一共猜了多少次,游戏结束,否则游戏继续。
"""
猜数字游戏
"""
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('你的智商余额明显不足')
"""
请输入: 50
大一点
请输入: 80
大一点
请输入: 90
小一点
请输入: 85
小一点
请输入: 83
大一点
请输入: 84
恭喜你猜对了!
你总共猜了6次
"""
上面的代码中使用了break关键字来提前终止循环,需要注意的是break只能终止它所在的那个循环,这一点在使用嵌套的循环结构(下面会讲到)需要引起注意。除了break之外,还有另一个关键字是continue,它可以用来放弃本次循环后续的代码直接让循环进入下一轮。
""" random模块 """ import random result = random.random() print result #生成0-1的随机数 print random.uniform(10,12) #10-12的随机数 print random.randint(30,50) #30-50的随机整数 print random.randrange(10,100,2) #从10开始到100结束,步长为2的序列中,随机选一个 list = [1,2,5,6,7,8,8] print random.choice(list) #从序列中随机选一个 random.shuffle(list) #重新排列序列 print list list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] slice = random.sample(list, 5) #从序列中取样 print slice
和分支结构一样,循环结构也是可以嵌套的,也就是说在循环中还可以构造循环结构。下面的例子演示了如何通过嵌套的循环来输出一个九九乘法表。
"""
乘法口诀表(九*九)
"""
for i in range(1,10):
for j in range(1,i + 1):
print('%d*%d=%d' %(j,i,i*j),end='t')
print()
"""
1*1=1
1*2=2 2*2=4
1*3=3 2*3=6 3*3=9
1*4=4 2*4=8 3*4=12 4*4=16
1*5=5 2*5=10 3*5=15 4*5=20 5*5=25
1*6=6 2*6=12 3*6=18 4*6=24 5*6=30 6*6=36
1*7=7 2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=49
1*8=8 2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=64
1*9=9 2*9=18 3*9=27 4*9=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81
"""
练习
练习1:输入一个正整数判断是不是素数。
提示:素数指的是只能被1和自身整除的大于1的整数。
"""
输入一个正整数判断它是不是素数
"""
from math import sqrt
num = int(input('请输入一个正整数:'))
a = int(sqrt(num))
is_prime = True
for x in range(2,a+1):
if num % x == 0:
is_prime = False
break
if is_prime and num != 1:
print('%d是素数' %num)
else:
print('%d不是素数' %num)
练习2:输入两个正整数,计算它们的最大公约数和最小公倍数。
提示:两个数的最大公约数是两个数的公共因子中最大的那个数;两个数的最小公倍数则是能够同时被两个数整除的最小的那个数。
"""
输入两个正整数,计算它们的最大公约数和最小公倍数。
"""
print('请输入两个正整数')
a = int(input('a = '))
b = int(input('b = '))
if a > b:
a,b = b,a
for x in range(a,0,-1):
if a % x == 0 and b % x == 0:
print('%d和%d的最大公约数是%d' %(a,b,x))
print('%d和%d的最小公倍数是%d' %(a,b,a*b/x))
break
练习3:打印如下所示的三角形图案。
*
**
***
****
*****
*
**
***
****
*****
*
***
*****
*******
*********
"""
打印三角形图案
"""
row = int(input('请输入行数: '))
for i in range(row):
for j in range(i+1):
print('*',end='')
print()
for i in range(row):
for j in range(row):
if j < row -1- i:
print(' ', end='')
else:
print('*', end='')
print()
for i in range(row):
for j in range(row - i - 1):
print(' ', end='')
for j in range(2 * i + 1):
print('*', end='')
print()
"""
请输入行数: 5
*
**
***
****
*****
*
**
***
****
*****
*
***
*****
*******
*********
"""



