




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、计算机编程导论,第4章 循环结构 程序设计2,计算机编程导论,4.3.3 while语句用于无限循环,要点: 循环结构理解 二重循环结构理解 二重循环的应用,计算机编程导论,4.3.3 while语句用于无限循环,当while语句的“表达式”永远不会为布尔假时,循环将永远不会结束,形成无限循环,也称死循环。 使用while语句构成无限循环的格式通常为: while true: 循环体 可以在循环体内使用break语句强制结束死循环,计算机编程导论,例4-5】使用无限循环的方法编程实现例4-2,a = input(请输入字符,如果输入 # 号则结束输入操作: ) while true: prin
2、t(您输入的字符是:, a) a = input(请输入字符,如果输入 # 号则结束输入操作: ) if a = #: break,程序,计算机编程导论,例4-6】求以下表达式的值,其中n值从键盘输入。参考值:当n = 11时,s = 1.833333,计算机编程导论,分析】 (1)以上问题属于数学中的级数求和问题,是使用循环结构解决的一类常见问题。 (2)级数求和问题编程的重点在于通过观察表达式的规律,分析每次循环都要完成的事件。通常将这些事件进行局部分解,称为“通式,该题的通式有以下几个: (1)分母的通式: (2)变量i的通式: (3)当前项的通式: (4)求和的通式,mu = mu +
3、 i,i = i + 1,t = 1.0 / mu,s = s + t,计算机编程导论,i=1 mu = 0 s = 0.0 n = input(请输入n值: ) #或用书上的代码 while i = n: #判断是否计算到表达式的最后一项 mu = mu + i #求分母的通式 i += 1 # i 自增的通式 t = 1.0 / mu #求当前项的通式 s = s + t #求和的通式 print s = , s #循环结束后,打印总和,程序,提问,1)变量 i、mu、s 的初值只能是 1、0、0.0 吗? (2)循环体内语句的先后顺序可以随意调换吗,计算机编程导论,例4-7】 通过以下表
4、达式求的近似值,当某项小于0.00000001(即1e-8)时停止循环,计算机编程导论,分析: 该题使用循环结构来解决,只有当某一项小于1e-8时才停止迭代,因此循环次数是不确定的。观察表达式中相邻两项的规律是前一项的分子乘以1个整数值“i”可得后一项的分子,而这个整数值“i”随着循环次数由1递增到n;前一项的分母乘以“2*i+1”可得后一项的分母。该题的通式有以下几个: (1)分子的通式:zi = zi * i (2)分母的通式:mu = mu * (2 * i + 1) (3)变量i的通式:i = i + 1 (4)当前项的通式:t = zi*1.0/mu (5)求和通式:s=s+t,计算
5、机编程导论,程序: #exp4_7.py i = 1 zi = 1.0 mu = 1.0 t = 1.0 s = 0.0 while t = 1e-8: s = s + t zi = zi * i mu = mu * ( 2 * i + 1) t = zi * 1.0 / mu i += 1 print pai = , (2 * s,计算机编程导论,例4-8】求1 100之间能被7整除,但不能同时被5整除的所有整数,分析】 (1)本题需要对1 100范围内的所有数一一进行判断。 (2)本题的循环次数确定是100次。 (3)在每次循环过程中需要用 if 语句进行条件判断。因此本题是循环嵌套选择的
6、结构,计算机编程导论,i = 1 # i 既是循环变量,同时又是被判断的数 print(1100之间能被7整除,但不能同时被5整除的所有数是:) while i = 100: #判断循环是否结束 if i % 7 = 0 and i % 5 != 0: #判断本次的i是否满足条件 print i, t #打印满足条件的i i += 1 #每次循环 i 应自增,程序,提问,请问语句“i += 1”可以和语句 “print i, t ”对齐吗,计算机编程导论,例4-9】输出“水仙花数”。所谓水仙花数是指1个3位的十进制数,其各位数字的立方和等于该数本身。例如:153是水仙花数,因为153 = 13
7、 + 53 + 33,分析】 (1)本题需要对100 999范围内的所有数一一进行判断。 (2)本题的变量 i 既是循环变量,同时也是被判断的数。 (3)每次循环过程中需要用 if 语句进行条件判断。因此本题也是循环嵌套选择的结构,计算机编程导论,提问,变量 i 是一个三位整数,例如 i = 123 (1)请写出分离 i 的百位数的表达式。 (2)请写出分离 i 的十位数的表达式。 (3)请写出分离 i 的个位数的表达式,i = 100 print(所有的水仙花数是:) while i = 999: #判断循环是否结束 bai = int(i / 100) #分离 i 的百位数 shi = i
8、nt(i % 100) / 10) #分离 i 的十位数 ge = int(i % 10)#分离 i 的个位数 if bai * 3 + shi * 3 + ge * 3 = i: #判断条件 print i #打印水仙花数 i += 1 #变量 i 自增,程序,计算机编程导论,4.4 for语句,for 取值 in 序列: 循环体,循环体,python提供的另一个循环机制是for语句,它提供了python中最强大的循环结构。python中的for语句与传统的for语句不太一样,它接受可迭代对象(例如序列或迭代器)作为其参数,每次迭代其中的一个元素,计算机编程导论,列表、元组、字符串都是序列。
9、序列类型有着相同的访问模式:它的每一个元素可以通过指定一个偏移量的方式得到;而多个元素可以通过切片操作的方式得到。 序列操作可以通过很多内建函数来实现,比如求序列长度len( );求最大值max( ) ;最小值min( ) ;求和sum( );排序sorted( ) 等,以上这些内建函数的实现都离不开循环结构,4.3.1 for语句用于序列类型,计算机编程导论,例4-10】创建1个由分数构成的列表,求出所有分数的平均分,方法一:使用python的内建函数sum( )求和,然后再求平均分,score = 70, 90, 78, 85, 97, 94, 65, 80 score 70, 90, 7
10、8, 85, 97, 94, 65, 80 aver = sum(score) / 8.0 aver 82.375,计算机编程导论,方法二:使用for语句,循环计算列表元素之和,分析】 (1)以上列表score有8个元素,这些元素的序列索引范围是“0 7”。 (2)本题用到成员测试运算符“in”,如果成员在序列中,测试结果为“true”,否则为“false”。 (3)本题用到计算序列长度的内建函数len( )。 (4)本题用到内建函数range( ),range( )函数的完整语法要求提供2个或3个整型参数: range(start, end, step,计算机编程导论,score = 70,
11、 90, 78, 85, 97, 94, 65, 80 print 所有的分数值是: print score #打印列表 sum = 0 for i in range(len(score): print scorei, sum += scorei #循环体对列表元素求和 aver = sum / 8.0 #循环之后,求平均值 print naver = , aver,程序,计算机编程导论,循环的嵌套是指在一个循环中又包含另外一个完整的循环,即循环体中又包含循环语句。while循环和for循环可以相互嵌套。 循环嵌套的执行过程是:一次外循环对应着完整的一轮内循环,利用for语句实现双层循环嵌套,
12、计算机编程导论,例4-13】使用for循环的嵌套结构打印9-9乘法表,分析】9-9乘法表由9行组成,每行的列数有规律地递增。通过观察可以看出,表达式“x * y = z”中的x是内循环变量j的取值,y是外循环变量i的取值,z是x乘以y的结果,计算机编程导论,for i in range(1, 10, 1): #控制行 for j in range(1, i+1, 1): #控制列 print i, *, j, =, i*j, t print n #每行末尾的换行,程序,计算机编程导论,课堂练习】使用for循环的嵌套结构编程,打印以下图形,1)矩形,2)直角三角形,3)正三角形,计算机编程导论,
13、python提供了一条提前结束循环的语句break语句。 当在循环过程中,某个条件被触发(一般通过if语句检查),需要立即停止循环时使用。break语句可以用在while和for循环中,4.4 break语句,计算机编程导论,例4-15】求200以内能被17整除的最大正整数,分析】这个查找过程将以递减的方式遍历200至1之间的整数,当找到第1个能被17整除的数时,循环过程立即停止,后续还没有遍历的数将无需再进行判断,因此可以使用break语句将循环提前终止,for i in range(200, 1, -1): if i % 17 = 0: break print(200以内能被17整除的最大
14、数是:, i,程序,计算机编程导论,例4-16】从键盘输入一个整数,判断该数是否为素数,计算机编程导论,exp4_16.py x=input(请输入1个整数:) for i in range(2, x, 1): if x % i=0: break if i=x-1: print x, 是素数 elif ix-1: print x, 不是素数,计算机编程导论,4.6 continute语句,continue语句的作用是终止当前循环,并忽略continue之后的语句,然后回到循环的顶端,继续执行下一次循环,计算机编程导论,例4-17】 求200以内能被17整除的所有正整数,并统计满足条件的数的个数,exp4_17_2.py s=0 print 200以内能被17整除的所有数是: for i in range(1, 201
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 智能交通系统在城市管理中的应用与前景
- 商业空间装修协议书样本
- 停车场智能管理公司
- 现代农业金融创新方案
- 新型智能穿戴产品设计手册
- 电信行业智能化通信网络智能化管理与维护方案
- 豆制品加工项目可行性报告
- 长兴垃圾焚烧发电项目
- 商贸城项目可行性研究报告
- 关于提升员工职业技能的培训教程与计划安排
- 《8 家庭养鸡》(教案)-2023-2024学年六年级下册综合实践活动皖教版
- 小学百科知识题库大全
- HG∕T 4594-2014 热固性粉末涂料冷却压片设备
- 《电工电子技术》高职全套教学课件
- 碳九加氢工艺流程
- 智能网联汽车第三章毫米波雷达课件
- 标准B级机房建设方案
- MT-T 1199-2023 煤矿用防爆柴油机无轨胶轮运输车辆安全技术条件
- 项目四任务一《三股辫我会编》(课件)浙教版二年级下册综合实践活动
- 《生活垃圾填埋场开挖筛分技术规范》编制说明
- 《社区康复》课件-第三章 社区康复的实施
评论
0/150
提交评论