天天看点

算法设计的要求

算法设计的要求

掌握好的算法,对我们解决问题很有帮助,要想学习掌握好的算法,有必要先了解一下算法的设计要求有哪些:

正确性:算法的正确性是指算法至少应该具有输入、输出和加工处理无歧义性、能正确反映问题的需求、能够得到问题的正确答案。

但是算法的“正确”通常在用法上有很大的差别,大体分为以下四个层次:1.算法程序没有语法错误。2.算法程序对于合法的输入数据能够产生满足要求的输出结果。3.算法程序对于非法的输入数据能够得出满足规格说明的结果。4.算法程序对于精心选择的,甚至刁难的测试数据都有满足要求的输出结果。一般情况下,我们把层次3作为一个算法是否正确的标准。

可读性:我们写代码的目的,一方面是为了让计算机执行,但还有一个重要目的是为了便于他人阅读,让人理解和交流,自己将来也节能阅读,如果可读性不好,时间长了自己都不知道写了什么。可读性是算法(也包括实现它的代码)好坏很重要的标志。

健壮性:当输入数据不合法时,算法也能做出相关处理,而不是产生异常或莫名其妙的结果。

时间效率高和存储量低:时间效率指的是算法的执行时间,对于同一个问题,如果有多个算法能够解决,执行时间短的算法效率高,反之效率低。存储量是指算法在执行过程中需要的最大存储空间,主要指算法程序运行时所占用的内存或外部硬盘存储空间。设计算法应该尽量满足时间效率高和存储量低的需求。

继续阅读