算法:
一个有限指令集
接受一些输入(有些情况下不需要收入)
产生输出
一定在有限步骤之后终止
每一条指令必须:
有充分明确的目标,不可以有歧义
计算机能处理的范围之内
描述应不依赖于任何一种计算机语言以及具体的实现手段
其实说白了,算法就是一个计算过程解决问题的方法。我们现在已经知道数据结构表示数据是怎么存储的,而“程序=数据结构+算法”,数据结构是静态的,算法是动态的,它们加起来就是程序。
对算法来说有输入,有输出,相当于函数有参数有返回值。我们写算法的时候习惯把算法封装到一个函数中。
好,从上面我们知道了什么是算法,下面我再说什么是好的算法?
在解决同一个问题的时候,我们通常会有很多种不一样的算法,区别就在于,有的算法比较笨,有的算法比较聪明,那我们怎么去衡量它们谁好谁坏呢?我们通常有下面两个指标:
空间复杂度:根据算法写成的程序在执行时占用存储单元的长度。
时间复杂度:根据算法写成的程序在执行时耗费时间的长度。
先举个例子说,如果让你打印十个整数,你那个程序可能瞬间就给出结果了,如果让你打印十万个整数呢?这你就得多等一会了。所以这个程序运行的时间,就跟你要处理的数据是十个还是十万个是相关的,这个十或十万就是我们要处理的数据的规模。我们把它叫做n,是一个变量的话,那我们这个程序所用的时间和空间都跟这个n是有直接关系的。解决一个问题有很多中不同的方法,你在设计这个方法的时候,一定要把这两个要素考虑清楚。一不小心,如果空间复杂度太大的话,你那个程序就可能直接爆掉了,非正常中断,我一会会在后面讲,时间复杂度如果太大的话,你就可能等很长时间都等不出结果。
四组代码中,哪组的运行时间最短?
用什么方式来体现算法运行的快慢?
刚才说n可以看作数据的规模,规模不一样,运行时间肯定也不一样,而且所用时间也不好确定,不同的n会得到不同的时间,所以我们用时间复杂度来表示算法运行的快慢。
先来看下面图片中的几个生活中的事件,估计时间:
for i in range(n):
print('Hello World')
它的时间复杂度表示为O(n),因为这组代码执行了n次。n还是个单位,同理,分析第三个:
for i in range(n):
for j in range(n):
print('Hello World')
它的时间复杂度表示为O(),因为是有两层循环,所以是,还是个单位。第四个你自己就可以分析了,我就不多此一举了。但千万不要以为就是这么简单,咱再看下面代码图片:
看到这个图片,你是不是感觉很良好,和你猜的差不多是吧,哈哈,不要高兴的太早,告诉你们,错了,它们的时间复杂度不是这样的。
为什么?我说了,“1”是单位,但“3”不是单位,3是3乘1,就比如说在生活中,问你一壶水烧多长时间,没有人回答说是三个几分钟或者几个三分钟。再说第二个,是单位,n也是个单位,但是比n大,所以我们在估计时用大单位,就好比生活中问你大概睡了多久,你一般说是几个小时,而不是说几个小时零几分钟,你强调的是一个大概的时间,明白了吧。
所以正确的时间复杂度是这样的:
时间复杂度是用来估计算法运行时间的一个式子(单位)
一般来说,时间复杂度高的算法比时间复杂度低的算法慢
留言打卡 DAY 11
今日的留言话题是:留言补充分享下说说算法学得怎么样了?觉得难吗?说说理由?关于留言打卡的规则可以参考 留言打卡送福利(点击链接查看详细打卡规则),请按照 昵称+天数(请以自己实际打卡的天数为准,如day1 or day2 or day3)+ 留言内容(不少于15字)的方式留言。
往期推荐:
官宣:新版 VS Code 支持 Web 版 VS Code!
用python来验证一下天猫双十一数据造假?
搞懂这10 行代码,究竟有多难?
编程面试题库