04.循环结构.md 5.8 KB
Newer Older
J
jackfrued 已提交
1
## 循环结构
2

3
### 应用场景
4

J
jackfrued 已提交
5
如果在程序中我们需要重复的执行某条或某些指令,例如用程序控制机器人踢足球,如果机器人持球而且还没有进入射门范围,那么我们就要一直发出让机器人向球门方向奔跑的指令。当然你可能已经注意到了,刚才的描述中不仅仅有需要重复的动作,还需要用到上一章讲的分支结构。再举一个简单的例子,我们要实现一个每隔1秒中在屏幕上打印一次"hello, world"并持续打印一个小时的程序,我们肯定不能够直接把`print('hello, world')`这句代码写3600遍,如果真的要这样做,那么编程的工作就太无聊乏味了。因此,我们还需要了解一下循环结构,有了循环结构我们就可以轻松的控制某件事或者某些事重复、重复、再重复的去执行。
6 7

在Python中构造循环结构有两种做法,一种是`for-in`循环,一种是`while`循环。
8 9 10

### for-in循环

11
如果明确的知道循环执行的次数或者要对一个容器进行迭代(后面会讲到),那么我们推荐使用`for-in`循环,例如下面代码中计算1~100求和的结果($\displaystyle \sum \limits_{n=1}^{100}n$)。 
12 13 14 15 16 17 18 19 20 21 22

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

Version: 0.1
Author: 骆昊
"""

sum = 0
for x in range(101):
J
jackfrued 已提交
23
    sum += x
24 25 26
print(sum)
```

J
jackfrued 已提交
27
需要说明的是上面代码中的`range(101)`可以用来构造一个从0到100的取值范围,这样就可以构造出一个整数的序列并用于循环中,例如:
28 29 30

- `range(101)`可以产生一个0到100的整数序列。
- `range(1, 100)`可以产生一个1到99的整数序列。
J
jackfrued 已提交
31
- `range(1, 100, 2)`可以产生一个1到99的奇数序列,其中2是步长,即数值序列的增量。
32 33 34 35 36 37 38 39 40 41 42 43 44

知道了这一点,我们可以用下面的代码来实现1~100之间的偶数求和。

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

Version: 0.1
Author: 骆昊
"""

sum = 0
for x in range(2, 101, 2):
J
jackfrued 已提交
45
    sum += x
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
print(sum)
```

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

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

Version: 0.1
Author: 骆昊
"""

sum = 0
for x in range(1, 101):
J
jackfrued 已提交
61 62
    if x % 2 == 0:
        sum += x
63 64 65 66 67
print(sum)
```

### while循环

68
如果要构造不知道具体循环次数的循环结构,我们推荐使用`while`循环。`while`循环通过一个能够产生或转换出`bool`值的表达式来控制循环,表达式的值为`True`循环继续,表达式的值为`False`循环结束。下面我们通过一个“猜数字”的小游戏(计算机出一个1~100之间的随机数,人输入自己猜的数字,计算机给出对应的提示信息,直到人猜出计算机出的数字)来看看如何使用`while`循环。
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84

```Python
"""
猜数字游戏
计算机出一个1~100之间的随机数由人来猜
计算机根据人猜的数字分别给出提示大一点/小一点/猜对了

Version: 0.1
Author: 骆昊
"""

import random

answer = random.randint(1, 100)
counter = 0
while True:
J
jackfrued 已提交
85 86 87 88 89 90 91 92 93
    counter += 1
    number = int(input('请输入: '))
    if number < answer:
        print('大一点')
    elif number > answer:
        print('小一点')
    else:
        print('恭喜你猜对了!')
        break
94 95
print('你总共猜了%d次' % counter)
if counter > 7:
J
jackfrued 已提交
96
    print('你的智商余额明显不足')
97 98
```

J
jackfrued 已提交
99
上面的代码中使用了`break`关键字来提前终止循环,需要注意的是`break`只能终止它所在的那个循环,这一点在使用嵌套的循环结构(下面会讲到)需要引起注意。除了`break`之外,还有另一个关键字是`continue`,它可以用来放弃本次循环后续的代码直接让循环进入下一轮。
100 101 102 103 104 105 106 107 108 109 110 111

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

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

Version: 0.1
Author: 骆昊
"""

for i in range(1, 10):
J
jackfrued 已提交
112 113 114
    for j in range(1, i + 1):
        print('%d*%d=%d' % (i, j, i * j), end='\t')
    print()
115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
```

### 练习

#### 练习1:输入一个数判断是不是素数。

```Python
"""
输入一个正整数判断它是不是素数

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):
J
jackfrued 已提交
135 136 137
    if num % x == 0:
        is_prime = False
        break
138
if is_prime and num != 1:
J
jackfrued 已提交
139
    print('%d是素数' % num)
140
else:
J
jackfrued 已提交
141
    print('%d不是素数' % num)
142 143 144 145 146 147 148 149 150 151 152 153 154 155 156
```

#### 练习2:输入两个正整数,计算最大公约数和最小公倍数。

```Python
"""
输入两个正整数计算最大公约数和最小公倍数

Version: 0.1
Author: 骆昊
Date: 2018-03-01
"""

x = int(input('x = '))
y = int(input('y = '))
J
jackfrued 已提交
157
# 如果x大于y就交换x和y的值
158
if x > y:
J
jackfrued 已提交
159
    # 通过下面的操作将y的值赋给x, 将x的值赋给y
J
jackfrued 已提交
160
    x, y = y, x
161
for factor in range(x, 0, -1):
J
jackfrued 已提交
162 163 164 165
    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
166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217
```

#### 练习3:打印三角形图案。

```Python
"""
打印各种三角形图案

*
**
***
****
*****

    *
   **
  ***
 ****
*****

    *
   ***
  *****
 *******
*********

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