摘要:《零基础学Python》一书的学习记录,学习笔记。(连载之四)
回顾:昨天简单地学习了Python中的数据类型,数字和字符串,以及 算数表达式和和逻辑表达式。
Python的控制语句
Python的控制语句由条件判断语句、循环语句构成。
结构化程序设计
结构化程序设计类似于施工首先打好图纸(或图纸了然于胸),然后按照图纸一步一步走下去。我们数学上曾经接触过的程序框图就是一种重要的图纸。
条件判断语句
条件判断语句用于检测某个条件是否成立;如果成立,则执行if语句内的内容,否则跳过if语句,执行后面的内容。
if语句的格式如下
if(表达式):
语句1
else
语句2
if语句将判断“表达式”的布尔值,若为真,则执行语句1,否则,执行语句2.其中也可以不使用else及其子句;表达式两遍的括号也可以省略。
if...elif..else判断语句
if(表达式1):语句1
elif(表达式2):语句2
...
elif(表达式n):语句n
else:语句n+1
if...elif..else判断语句相当于是对if...else语句的补充,弥补它的不足,含义也是一目了然。
switch语句的替代方案
在其他高级语言中,switch语句也可以用于编写多分支结构的程序,功能类似于if...elif...else,却更为清晰;结构如下:
switch(表达式){
case 常量表达式1: 语句1
case 常量表达式2: 语句2
...
case 常量表达式n: 语句n
default: 语句n+1
}
执行switch时,首先判断“表达式”的值,与常量表达式1~n进行比较,比对成功则执行对英语剧,若无相同的常量表达式,执行default后语句。
遗憾的是Python并不支持switch,但是可以使用其他方案来实现switch的功能:
实现方法分为两步,首先,定义一个字典,字典是由键值对组成的集合,(关于字典的内容将在后续数据结构中介绍),在通过调用字典的get()获取相应的表达式。
# 使用字典实现switch语句
from __future__ import division
x = 1
y = 2
operator = "/"
result = {
"+" : x + y,
"-" : x - y,
"*" : x * y,
"/" : x / y
}
print (result.get(operator))
关于第一行from __future__ import division
,意味导入Python未来支持的语言特征division(精确除法),即1/2不再等于0,而是等于0.5,前者我们称为截断除法,后者称为精确除法。
循环语句
循环语句是指重复执行同一段代码块,通常用于遍历集合或者累加计算。有while循环语句和for循环语句。
while循环
while(表达式):
...
else:
...
当循环表达式(while后的“表达式”)为真时,执行while中的语句,知道表达式为False,程序的流程转到else语句中,其中else子句可以省略,表达式两侧的括号也可以省略。
for循环
for 变量 in 集合:
...
else:
...
每次循环从集合中取出一个值,并把该值赋给变量。集合可以是元组、列表、字典等数据结构,其中else子句可以省略。最后一次循环结束后将执行else子句。
for循环经常与range()函数一起使用,range()返回一个列表,for...in...遍历列表中的元素。在实例中会加深理解,说再多不如试一遍效果好,下面将会把书中的习题演示一遍。。
break和continue语句
break语句可以使程序跳出循环,continue则会终止此次循环,执行下一轮循环。
习题
1.Python中break和continue语句有什么不同?分别在什么情况下使用?
答:前面已经提到过,break用来跳出循环,continue也用来跳出循环,与break不同的是,continue不会跳出整个循环体,只是跳过当前循环,继续执行后面的循环。
2.使用结构化编程思想实现冒泡排序。
#-*- coding:utf-8 -*-
# 冒泡排序
def bubbleSort(numbers):
for j in range(len(numbers) - 1, -1, -1):
for i in range(j):
if numbers[i] > numbers[i+1]:
numbers[i], numbers[i+1] = numbers[i+1],
numbers[i]
print (numbers)
def main():
numbers = [23, 12, 9, 15, 6]
bubbleSort(numbers)
if __name__ == '__main__':
main()
range()函数有三个参量,第一个start表示列表开始的值,默认为0;第二个参数stop表示列表结束的值,这个参数不可缺少;第三个参数step表示步长,即每次递增递减的值,默认为1。
冒泡排序的原理:比较相邻的元素,如果前一个大于后一个,就交换它们(以从小到大为例),对每一组相邻元素做同样的工作,需要操作的对数逐渐减少,从第一对到最后一对,直到没有任何一对需要比较。
循环的嵌套,第一层循环j限定了i的范围,从列表的长度数减一,递减1直到-1;也就是说j的范围为4到0,。
第二层循环省略了start和step,stop的值为j,也就是说i的范围为0到j-1;在这层循环体中执行了以此比较相邻的数的功能。
最后定义主函数以及主函数的入口,按照书中来的。
网友评论