版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第二章算法与问题解决引入一个农夫要将一匹狼、一只羊和一筐菜运到河对岸。但他的船太小,一次只能带一样。当他不在时,狼要吃羊、羊会吃菜。怎样乘船才能安全地把这些东西运过河?分析问题食物链解决问题第一次:先带羊过去;第二次:把狼带过去,返程时再把羊带回来;第三次:把蔬菜带过去;第四次:最后把羊带过去。寻找解决问题方法,可以称之为算法解决问题第一次:先带羊过去;第二次:把狼带过去,返程时再把羊带回来;第三次:把蔬菜带过去;第四次:最后把羊带过去。寻找解决问题方法,可以称之为算法算法的概念古代的算法古代的算法主要指的是”算术”,即数值的算术运算。随着科学技术的发展,算法的外延和内涵逐渐发生着变化。广义算法算法指的是解决问题或完成任务的一系列步骤。既包括传统意义上计算任务,也可以是生活中各种事物的处理。计算机算法计算机领域内,算法指的是用计算机解决问题的步骤。是为了解决问题而让计算机有序执行的、无歧义的,有限步骤的集合。算法的特征问题:1、判断抛物线y=5x2+4x+6与X轴是否有交点。2、设计一个算法,要求输入X的一个值后,输出相应的绝对值。算法:1、计算∆=42-4*5*6;2、如果∆>0,执行步骤3,否则执行步骤4;3、输出有交点,结束;4、输出无交点,结束。分析项目抛物线绝对值执行步骤个数每一步是否明确可执行是否有输入是否有输出4是否是4是是是算法的特征有穷性:计算步骤是有限的确定性:每一个步骤必须有确切的定义数据输入:必须有0个或多个数据输入数据输出:必须有1个或多个数据输出可行性:每个步骤都可以在有限时间内完成死循环?随便进行?大致就行?0个输入是算法本身给出了初始条件无功而返?可以得出结果。算法的要素如何确定工作多久?如何记录进水量的?如何记录工作时间?时间达标了会干嘛?不达标会干嘛?数据运算控制转移算法的描述我们刚刚是如何描述一个算法的?文字描述→自然语言流程图算法的描述流程图伪代码算法的描述算法的描述用计算机程序设计语音描述算法基本结构—顺序结构算法描述的方法优势不足自然语言表示法用人们日常所用的语言,比较容易掌握。当算法中含有多分支或循环操作较多时很难清晰地表示出来,由于自然语言的歧义性,容易导致算法执行的不确定性。流程图表示法用程序框图来描述,流程描述清晰简洁。所占篇幅较大,由于允许使用流程线,过于灵活,不受约束。伪代码表示法用介于自然语言和计算机语言之间的文字和符号来描述,书写方便,格式紧凑,易于理解,便于向计算机程序设计语言过渡。由于编程语言的种类繁多,伪代码的语句不容易规范,有时会产生误解。计算机程序设计语言用计算机专门的语言来描述,精确性高,计算机可以直接运行。可移植,不同设备对于相同的代码都能运行计算机语言的学习成本高3.2Python语言程序设计3.2.1Python语言基础编程环境图3.2.1IDLE的操作界面解释器操作界面编辑器操作界面编程环境解释器操作界面编辑器操作界面敲一次回车运行一行代码编辑完成后,运行所有代码拓展链接集成开发环境(IDE)是提供程序开发环境的应用程序,一般包括代码编辑器、调试器和图形用户界面工具。目前,用于编写Python程序的IDE较多,如IDLE、Spyder、Wing、PyCharm等。如图3.2.2是Spyder的操作界面。图3.2.2spyder的操作界面编辑器解释器数据类型与表达式表3.2.1Python常见数据类型42.0是什么类型呢?“42.0”是什么类型呢?python是弱类型语言,相对于强类型语言,它不需要声明变量的类型。甚至粗暴到连声明关键字都省略了。数据按照其本身特征可以分为若干类型,常见的Python基本数据类型如表所示。数据类型与表达式数据信息分析运算010203Python算术运算符Python关系运算符Python逻辑运算符算术运算符算术运算是运用算术运算符进行数的加、减、乘、除等数学运算。优先程度最高级别为1,级别数字越大,优先级越低。a.2**10b.3*4–5*6c.123-123//100*100d."Who"+"Am"+"I?"字符串运算符:”*”用于重复字符串关系运算符关系运算的结果是一个布尔值,若两个数据之间指定的关系成立,则结果为真(True),否则为假(False)。关系运算符的优先级全部相同,但低于算术运算符,优先级为4关系运算符表3.2.3Python关系运算符逻辑运算法表3.2.4Python逻辑运算符逻辑运算符经常用于描述复杂情况的判断。逻辑运算符的优先级各不相同:not优先级为5,and优先级为6,or优先级为7。运算符的优先级优先程度最高级别为1,级别数字越大,优先级越低。和数学一样,括号的优先级最高,高于任何运算符,有括号先算括号变量和赋值语句运算符描述实例=基本赋值运算符c=a+b将a+b的运算结果赋值给c+=加法赋值运算符c+=a等效于c=c+a−=减法赋值运算符c−=a等效于c=c−a*=乘法赋值运算符c*=a等效于c=c*a/=除法赋值运算符c/=a等效于c=c/a%=取模赋值运算符c%=a等效于c=c%a**=幂赋值运算符c**=a等效于c=c**a//=取整除赋值运算符c//=a等效于c=c//aa=160----变量为整型b=“test”----变量为字符型x=y=z=1----多重赋值x,y,z,=1,2,“string”----多元赋值abx=y=z=x,y,z,变量在首次赋值时产生,没赋值即不存在a35a5变量就是存放值的一段内存空间a=5a=31.变量名通常由字母,数字,下划线(_)组成;2.数字不能作为变量名开头;3.不能以python中的关键字命名(False、and、if);
3.help('keywords')查看4.建议变量名要有意义;5.不建议用汉字和拼音去命名;6.变量名要区分大小写(A和a是两个不同的变量);7.建议使用驼峰型(GuessAge或guessAge)和下3.3.划线(guess_age)来命名;8.常量通常使用全部大写来命名.课堂小练在PythonShell中输入:2+3*7,按回车键后,输出的结果是 ( )A.35 B.33 C.23 D.2+3*7 AAA选项错误BBB选项错误CCC选项正确,本题考查算术运算符,即数学中的运算DDD选项错误2.已知x="20",y="21",z=x+y,则print(z)的结果是 ( )A.41 B.2021C.''41'' D.''20"''21"AAA选项错误BBB选项正确,本题考查算术运算符在字符串中的运算CCC选项错误DDD选项错误课堂小练
AA
BBB正确,本题考查算术运算符CC
DD
4.下列表达式的值为False的是 ( )A.0orTrue B.TrueorFalseC.2<1and2<3
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年教育培训项目投资与合作合同
- 设立分公司技术试验协议
- 多元化中学门卫招聘协议
- 留学生合同范本
- 草场租赁合同:户外健身中心
- 乡镇公务员聘用合同
- 旅游项目融资抵押借款协议书
- 电力施工设备租赁合同
- 驾校训练场驾驶培训租赁合同
- 医院工程板房施工协议
- DB42T 1144-2016燃气用不锈钢波纹软管安装及验收规范
- 二级医院规章制度汇编
- 建筑物拆除工程监理实施细则
- 2023-2024学年安徽省合肥市小学数学五年级上册期末自测题
- GB/T 702-2017热轧钢棒尺寸、外形、重量及允许偏差
- 四年级上册英语试题-Unit 12 Peter can jump high 湘少版(含答案)
- 信息系统运行维护服务与方案(IT运维服务与方案)
- 培训宏业系统门店简易操作手册
- 《故都的秋》《荷塘月色》联读课件15张-统编版高中语文必修上册
- 初中篮球教学案例八年级体质课案-【教学参考】
- 毽球知识考题
评论
0/150
提交评论