【连载】《零基础学Python》笔记(四)

摘要:《零基础学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;在这层循环体中执行了以此比较相邻的数的功能。

最后定义主函数以及主函数的入口,按照书中来的。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容