03.初识程序的灵魂
原文:https://www.cnblogs.com/wanmeishenghuo/p/9484777.html
内容参考: 狄泰软件学院相关教程
程序并不是越短越好。
数据结构静态的描述了数据元素之间的关系。
高效的程序需要在数据结构的基础上设计和选择算法
高效的程序包括:恰当的数据结构和合适的算法
算法是特定问题的求解步骤,在计算机中表现为指令的有限序列
算法是独立存在的一种解决问题的方法和思想
对于算法而言,语言并不重要,重要的是思想
算法的特性:
1、输入:算法具有0个或者多个输入
2、输出:算法至少有1个或者多个输出
3、有穷性:算法在有限的步骤之后会自动结束而不会无限循环,在可接受的时间内能够自动结束
4、确定性:算法中的每一步都有确定的含义,不会出现二义性,只要输入一致,输出也是一致的
5、可行性:算法的每一步都是可行的
正确性:正确性不同于确定性
算法对于合法数据能够得到满足要求的结果
算法能够处理非法输入,并得到合理的结果
算法对于边界数据和压力数据都能得到满足要求的结果
注意:
正确性是算法最需要满足的基本的准则,但是作为计算机程序,不可能无限制的满足这条准则。因此,我们只需要关注:在用户的数据范围之内,我们能得到正确的结果就行了。对于用户不关注的数据,我们也完全不用考虑。或者将用户不关注的数据当做非法输入来处理。
算法还需要有以下的附加特性:
可读性:
算法要方便阅读、理解和交流
健壮性:
算法不应该产生莫名其妙的结果,给同样一组数据,在任何时候都会得到同样的结果,不能早上运行可以得到结果,晚上运行就崩溃
性价比:
利用最少的资源得到满足要求的结果
总结:
posted on 2020-03-15 21:46 lh03061238 阅读(118) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)