算法特征与表达方式-程序设计基础
需积分: 35 84 浏览量
更新于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`的值以避免计算平方根时出现错误。
通过深入理解和熟练掌握这些基本概念,程序员可以设计出高效、可靠的程序,从而解决各种复杂问题。
2245 浏览量
点击了解资源详情
点击了解资源详情
1020 浏览量
230 浏览量
159 浏览量
190 浏览量
329 浏览量
874 浏览量
西住流军神
- 粉丝: 31
- 资源: 2万+
最新资源
- api-health-check:Angular项目
- library_system_ruby:图书馆管理系统-Ruby on Rails
- ositestats:网络统计、分析服务器。 PageImpressions、Uniques、流量来源分布、BrowserOs、..
- MyPSD_demo.zip
- P7
- Microsoft Visual Studio Installer Projects
- Abcd PDF - Chrome新标签页-crx插件
- local_library:MDN的“本地库”快速(节点)教程
- PassSlot:使用Mule的PassSlot应用程序
- 员工管理信息系统.rar
- Ameyo | Task + Habit Tracker-crx插件
- T3
- Python训练营
- PUBG引擎源码.7z
- xiaozhao:校园招聘过程中,整理的知识点,包含计算机网络,操作系统,组成原理,Java基础,设计模型等
- Search Keys-crx插件