算法特征与表达方式-程序设计基础
需积分: 35 150 浏览量
更新于2024-08-23
收藏 351KB PPT 举报
"这篇资料是谭浩强关于C语言程序设计的笔记,主要讨论了算法的特征和表达方式,以及程序设计方法中的选择结构。"
算法是计算机科学的基础,是解决问题的具体步骤序列。在本资料中,算法的五个特征被详细阐述:
1. **有穷性**:算法必须在有限的步骤内完成,不能陷入无限循环。这意味着算法执行的次数是有限制的,最终能够得出结果。
2. **确定性**:算法的每一步都有明确的定义,不存在模糊不清的操作。对于给定的输入,算法的执行结果应该是确定的,不受外部不确定因素影响。
3. **输入**:算法可以接受零个或多个输入,这些输入是从外部获取的信息,用于驱动算法进行计算。
4. **输出**:算法至少产生一个输出,这是处理输入后得到的结果,反映了算法执行的效果。
5. **有效性**:每个步骤都是可执行的,并且会产生确定的结果。有效的算法不仅需要正确,还应该考虑其时间和空间效率,即时间复杂度和空间复杂度。
资料中提到了不同类型的算法,例如数值运算和非数值运算。举例来说,找出一组数中的最大值就是一个简单的算法实例。同时,资料还讨论了算法的多种表达方式,包括:
- **自然语言**:用日常语言描述算法步骤。
- **流程图**:图形化表示算法流程,包括判断框、处理框、输入/输出框和流程线等。
- **N-S图**:一种无箭头的流程图,通过开始/结束框和处理框来表示算法。
- **伪代码**:介于自然语言和计算机语言之间的表达方式,方便理解且易于转换为实际代码。
- **计算机语言**:直接使用编程语言编写出的代码,是实现算法的最终形式。
资料还强调了结构化程序设计方法,包括自顶向下、逐步细化、模块化设计和结构化编码。这种方法鼓励程序员将大任务分解为小任务,使用基本的程序结构如:
1. **顺序结构**:按照顺序执行指令,例如`步骤1 -> 步骤2 -> 步骤3`。
2. **选择结构(分支结构)**:根据条件执行不同的语句组,例如`if-else`语句。
3. **循环结构**:重复执行某一部分代码,直到满足特定条件为止。
选择结构是程序设计中不可或缺的部分,通过`if`和`else`语句实现条件判断,确保程序在遇到不同情况时能够做出适当的响应。例如,解决一元二次方程的问题时,需要检查判别式`b^2 - 4ac`的值以避免计算平方根时出现错误。
通过深入理解和熟练掌握这些基本概念,程序员可以设计出高效、可靠的程序,从而解决各种复杂问题。
166 浏览量
2021-12-14 上传
2014-02-18 上传
2023-08-04 上传
2010-12-15 上传
2021-10-16 上传
2015-03-03 上传
2021-05-25 上传
2021-06-03 上传
西住流军神
- 粉丝: 31
- 资源: 2万+
最新资源
- C语言数组操作:高度检查器编程实践
- 基于Swift开发的嘉定单车LBS iOS应用项目解析
- 钗头凤声乐表演的二度创作分析报告
- 分布式数据库特训营全套教程资料
- JavaScript开发者Robert Bindar的博客平台
- MATLAB投影寻踪代码教程及文件解压缩指南
- HTML5拖放实现的RPSLS游戏教程
- HT://Dig引擎接口,Ampoliros开源模块应用
- 全面探测服务器性能与PHP环境的iprober PHP探针v0.024
- 新版提醒应用v2:基于MongoDB的数据存储
- 《我的世界》东方大陆1.12.2材质包深度体验
- Hypercore Promisifier: JavaScript中的回调转换为Promise包装器
- 探索开源项目Artifice:Slyme脚本与技巧游戏
- Matlab机器人学习代码解析与笔记分享
- 查尔默斯大学计算物理作业HP2解析
- GitHub问题管理新工具:GIRA-crx插件介绍