算法第一讲(时空复杂度)
算法计算复杂度计算方式
算法计算复杂度计算方式
算法的复杂度是评估算法性能的重要指标,它描述了算法运行
时间或空间需求随输入规模增长的趋势。
计算复杂度的方式通常有
两种,时间复杂度和空间复杂度。
时间复杂度是指算法解决问题所需的计算工作量,它衡量了算
法的执行时间。
时间复杂度通常用大O符号表示,如O(n)、O(n^2)等。
计算时间复杂度的方法是通过分析算法中基本操作执行的次数
来确定,然后找到随输入规模增长时的增长趋势。
空间复杂度是指算法解决问题所需的内存空间,它衡量了算法
的内存消耗。
空间复杂度也通常用大O符号表示,如O(1)、O(n)等。
计算空间复杂度的方法是通过分析算法中变量、数据结构和递归调
用等占用的内存空间来确定。
在实际应用中,计算复杂度的方式可以通过数学分析、递归关
系式、迭代关系式等方法来进行。
通过计算复杂度,我们可以评估
算法的效率和性能,选择合适的算法来解决问题,优化算法以提高
执行效率,从而更好地满足实际需求。
算法的复杂度计算方式对于
算法设计和分析具有重要的指导意义,是算法研究和应用中的基础和关键。
算法的时间复杂度和空间复杂度
相关知识介绍(所有定义只为帮助读者理解相关概念,并非严格定义):1、稳定排序和非稳定排序简单地说就是所有相等的数经过某种排序方法后,仍能保持它们在排序之前的相对次序,我们就说这种排序方法是稳定的。
反之,就是非稳定的。
比如:一组数排序前是a1,a2,a3,a4,a5,其中a2=a4,经过某种排序后为a1,a2,a4,a3,a5,则我们说这种排序是稳定的,因为a2排序前在a4的前面,排序后它还是在a4的前面。
假如变成a1,a4, a2,a3,a5就不是稳定的了。
2、内排序和外排序在排序过程中,所有需要排序的数都在内存,并在内存中调整它们的存储顺序,称为内排序;在排序过程中,只有部分数被调入内存,并借助内存调整数在外存中的存放顺序排序方法称为外排序。
3、算法的时间复杂度和空间复杂度所谓算法的时间复杂度,是指执行算法所需要的计算工作量。
一个算法的空间复杂度,一般是指执行这个算法所需要的内存空间。
功能:选择排序输入:数组名称(也就是数组首地址)、数组中元素个数算法思想简单描述:在要排序的一组数中,选出最小的一个数与第一个位置的数交换;然后在剩下的数当中再找最小的与第二个位置的数交换,如此循环到倒数第二个数和最后一个数比较为止。
选择排序是不稳定的。
算法复杂度O(n2)--[n的平方void select_sort(int *x, int n){int i, j, min, t;for (i=0; i<n-1; i++) /*要选择的次数:0~n-2共n-1次*/{min = i; /*假设当前下标为i的数最小,比较后再调整*/for (j=i+1; j<n; j++)/*循环找出最小的数的下标是哪个*/{if (*(x+j) < *(x+min)){min = j; /*如果后面的数比前面的小,则记下它的下标*/}}if (min != i) /*如果min在循环中改变了,就需要交换数据*/{t = *(x+i);*(x+i) = *(x+min);*(x+min) = t;}}/*功能:直接插入排序输入:数组名称(也就是数组首地址)、数组中元素个数算法思想简单描述:在要排序的一组数中,假设前面(n-1) [n>=2] 个数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数也是排好顺序的。
算法时间复杂度的计算公式
算法时间复杂度的计算公式算法时间复杂度是算法效率的一种度量方式,通常用大O符号来表示,例如O(1)、O(n)、O(n^2)等。
在计算算法时间复杂度时,需要考虑算法中各种操作的时间复杂度,并将它们合并为总时间复杂度。
以下是常见的算法操作时间复杂度:1. 常数级别:O(1)2. 对数级别:O(logn)3. 线性级别:O(n)4. 线性对数级别:O(nlogn)5. 平方级别:O(n^2)6. 立方级别:O(n^3)7. 指数级别:O(2^n)计算总时间复杂度的公式如下:1. 顺序执行的操作,时间复杂度直接相加。
例如,若有操作A、B、C,它们的时间复杂度分别为O(a)、O(b)、O(c),则总时间复杂度为O(a + b + c)。
2. 嵌套执行的操作,时间复杂度取最大值。
例如,若有操作A、B,操作A执行了n次,每次的时间复杂度为O(n),操作B的时间复杂度为O(nlogn),则总时间复杂度为O(n*nlogn),即O(n^2logn)。
3. 分支语句的时间复杂度为其中时间复杂度最大的分支的时间复杂度。
例如,若有分支语句,分别包含操作A和操作B,它们的时间复杂度分别为O(a)、O(b),则分支语句的时间复杂度为O(max(a,b))。
4. 循环结构的时间复杂度为循环次数乘以循环体的时间复杂度。
例如,若有循环结构,循环次数为n,循环体包含操作A和操作B,它们的时间复杂度分别为O(a)、O(b),则循环结构的时间复杂度为O(n*max(a,b))。
综上所述,计算算法总时间复杂度需要考虑各个操作的时间复杂度以及它们的执行顺序、嵌套关系、分支和循环结构。
算法的时间复杂度和空间复杂度的关系
算法的时间复杂度和空间复杂度的关系
时间复杂度和空间复杂度是算法分析中最重要的概念,它们可以帮助我们评估算法的性能。
时间复杂度描述了算法执行所需的时间,而空间复杂度描述了算法执行所需的内存空间。
时间复杂度是指算法执行所需的时间,它可以用大O表示法来表示,其中O(n)表示算法
的时间复杂度为n,即算法的执行时间与输入数据的大小成正比。
一般来说,算法的时间
复杂度越低,它的执行效率就越高。
空间复杂度是指算法执行所需的内存空间,它也可以用大O表示法来表示,其中O(n)表
示算法的空间复杂度为n,即算法所需的内存空间与输入数据的大小成正比。
一般来说,
算法的空间复杂度越低,它的内存使用效率就越高。
时间复杂度和空间复杂度之间存在一定的关系,即算法的时间复杂度越低,它的空间复杂度也越低。
这是因为算法的时间复杂度越低,它所需的计算量就越少,因此它所需的内存
空间也就越少。
反之,算法的时间复杂度越高,它所需的计算量就越多,因此它所需的内
存空间也就越多。
因此,我们可以从算法的时间复杂度来推断它的空间复杂度,从而更好地评估算法的性能。
但是,有时候算法的时间复杂度和空间复杂度可能不是成正比的,因此我们还需要对算法
的空间复杂度进行具体的分析,以便更好地评估算法的性能。
总之,时间复杂度和空间复杂度是算法分析中最重要的概念,它们可以帮助我们评估算法的性能。
算法的时间复杂度越低,它的空间复杂度也越低,但有时候它们之间的关系可能
不是成正比的,因此我们还需要对算法的空间复杂度进行具体的分析,以便更好地评估算
法的性能。
算法时间复杂度的计算公式
算法时间复杂度的计算公式
算法时间复杂度是衡量算法效率的重要指标,它是指算法运行时间随着问题规模的增大而增长的速度。
计算算法时间复杂度需要考虑以下几个因素:
1. 循环结构的次数:算法中循环结构执行的次数是影响时间复杂度的重要因素之一。
2. 嵌套循环结构:如果算法中有多个嵌套循环结构,那么时间复杂度的计算就要考虑这些循环的嵌套次数。
3. 条件判断语句:如果算法中有条件判断语句,那么时间复杂度的计算需要根据条件的判断次数进行计算。
4. 递归调用:如果算法中有递归调用,那么时间复杂度的计算需要根据递归的次数进行计算。
算法时间复杂度的计算公式可以表示为:
T(n) = O(f(n))
其中,T(n)表示算法的时间复杂度,f(n)表示算法执行的时间,O表示算法的渐进时间复杂度。
根据算法的实际情况,可以通过分析算法中循环结构的次数、嵌套次数、条件判断次数、递归次数等因素,来确定算法的时间复杂度。
- 1 -。
欧几里得算法的时间复杂度和空间复杂度
欧几里得算法的时间复杂度和空间复杂度下载提示:该文档是本店铺精心编制而成的,希望大家下载后,能够帮助大家解决实际问题。
文档下载后可定制修改,请根据实际需要进行调整和使用,谢谢!本店铺为大家提供各种类型的实用资料,如教育随笔、日记赏析、句子摘抄、古诗大全、经典美文、话题作文、工作总结、词语解析、文案摘录、其他资料等等,想了解不同资料格式和写法,敬请关注!Download tips: This document is carefully compiled by this editor. I hope that after you download it, it can help you solve practical problems. The document can be customized and modified after downloading, please adjust and use it according to actual needs, thank you! In addition, this shop provides you with various types of practical materials, such as educational essays, diary appreciation, sentence excerpts, ancient poems, classic articles, topic composition, work summary, word parsing, copy excerpts, other materials and so on, want to know different data formats and writing methods, please pay attention!欧几里得算法的时间复杂度和空间复杂度简介欧几里得算法,也称为辗转相除法,是一种用于计算两个非负整数的最大公约数的算法。
时间复杂度详解
时间复杂度详解时间复杂度详解什么是时间复杂度•时间复杂度是一种衡量算法执行效率的方式。
•它表示算法的运行时间与输入大小的关系,为我们提供了衡量算法性能的指标。
时间复杂度的表示•时间复杂度使用大O符号(O)来表示。
•O(n)表示算法的时间复杂度与输入规模n成正比。
常见的时间复杂度•O(1):常数时间复杂度,无论输入规模的大小,算法的执行时间都保持不变。
•O(log n):对数时间复杂度,随着输入规模的增加,算法的执行时间逐渐增长,但增长速度很慢。
•O(n):线性时间复杂度,算法的执行时间与输入规模n成比例增长。
•O(n log n):线性对数时间复杂度,随着输入规模的增加,算法的执行时间逐渐增长,但增长速度比O(n)慢。
•O(n^2):平方时间复杂度,算法的执行时间与输入规模n的平方成比例增长。
•O(2^n):指数时间复杂度,算法的执行时间随着输入规模n的增加而急剧增长。
•O(n!):阶乘时间复杂度,算法的执行时间随着输入规模n的增加而急剧增长。
如何计算时间复杂度•首先,确定算法的基本操作。
•其次,根据算法的基本操作,分析每个操作的时间复杂度。
•最后,根据每个操作的时间复杂度,确定整个算法的时间复杂度。
如何选择合适的算法•在设计算法时,我们应该选择时间复杂度低的算法。
•当输入规模较小时,可以选用时间复杂度较高但简单易懂的算法。
•当输入规模较大时,应该尽量选择时间复杂度较低的算法。
总结•时间复杂度是一种衡量算法执行效率的方式,它表示算法的运行时间与输入规模的关系。
•常见的时间复杂度包括常数时间复杂度、对数时间复杂度、线性时间复杂度等。
•计算时间复杂度的步骤包括确定算法的基本操作、分析每个操作的时间复杂度以及确定整体的时间复杂度。
•在选择算法时,应该根据输入规模选择合适的时间复杂度。
参考资料:[腾讯课堂-计算机科学与技术](。
空间复杂度怎么算
空间复杂度怎么算1.算法效率算法分析有两种:第一种是时间效率,第二种是空间效率。
时间效率叫时间复杂度,空间效率叫空间复杂度。
时间复杂度主要衡量一个算法的运行速度,空间复杂度主要衡量一个算法需要的额外空间。
在计算机发展的早期,计算机的存储容量非常小。
所以我非常关心空间的复杂性。
然而,随着计算机行业的快速发展,计算机的存储容量已经达到了很高的水平。
所以现在我们不需要特别关注一个算法的空间复杂度。
2.时间复杂度2.1时间复杂度的概念时间复杂度的定义:在计算机科学中,算法的时间复杂度是一个函数(数学中表达式未知的函数),定量描述算法的运行时间。
理论上,一个算法执行的时间是无法计算的。
只有把你的程序放到机器上运行,你才能知道。
但是我们需要在电脑上测试每一个算法吗?可以在电脑上测试,但是很麻烦,于是就有了时间复杂度分析法。
算法花费的时间与其语句的执行次数成正比,算法中基本运算的执行次数就是算法的时间复杂度。
3.空间复杂度空间复杂度是对一个算法在运行过程中临时占用存储空间大小量度。
空间复杂度不是程序占用了多少bytes的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数。
空间复杂度计算规则基本跟实践复杂度类似,也使用大O渐进表示法。
4.大O渐进表示法•大O符号(Big O notation):是用于描述函数渐进行为的数学符号。
推导大O阶方法:• 1.用常数1替换运行时的所有加法常数。
• 2.在操作次数的修正函数中,只保留最高阶项。
•3、如果最高阶项存在且不是1,则去除与这个项目相乘的常数。
得到的结果就是大O阶。
另外有些算法的时间复杂度存在最好、平均和最坏情况:•最坏情况:任意输入规模的最大运行次数(上界) 平均情况:任意输入规模的期望运行次数•最好情况:任意输入规模的最小运行次数(下界) 例如:在一个长度为N数组中搜索一个数据x 最好情况:1次找到最坏情况:N次找到•平均情况:N/2次找到在实际中一般情况关注的是算法的最坏运行情况,所以数组中搜索数据时间复杂度为O(N)5.常见时间复杂度计算一下这个算法的时间复杂度// 请计算一下Func1基本操作执行了多少次?voidFunc1(intN){intcount=0;//两层循环嵌套外循环执行n 次,内循环执行n次,整体计算就是N*N的执行次数for(inti=0;i<N;++i){for(intj=0;j<N;++j){++count;}}//2 * N的执行次数for(intk=0;k<2*N;++k){++count;}//常数项10intM=10;while(M--){++count;}printf("%d\n",count);}精确的时间复杂度是N ^ 2 + 2 * N + 10 大O的渐进表示法时间复杂度是O(N ^ 2) 分析: 1、两层循环嵌套外循环执行n次,内循环执行n次,整体计算就是N*N 的执行次数 2、2 * N的执行次数 3、常数项10 根据前面的大o渐进表示法规则,所以最后只保留那项对执行次数影响最大的那一项,时间复杂度就是O(N ^ 2)。
如何计算时间复杂度和空间复杂度
如何计算时间复杂度和空间复杂度计算时间复杂度和空间复杂度是衡量算法效率的重要方法,可以通过对算法的代码进行分析和推算来得出。
时间复杂度描述了算法运行时间随输入规模增长而增长的趋势,通常用大O符号表示。
在计算时间复杂度时,我们需要关注算法中的循环、递归、条件分支等关键代码块。
以下是计算时间复杂度的一些常见方法:1.计算常数时间复杂度:如果一个算法的代码只包含固定数量的操作,不随输入规模变化,那么它的时间复杂度为O(1)。
例如,简单的赋值、比较和常量运算等操作。
2.计算线性时间复杂度:如果一个算法的代码中包含一个循环,该循环的迭代次数与输入规模n成正比,那么其时间复杂度为O(n)。
例如,遍历一个数组或者链表的操作。
3.计算平方时间复杂度:如果一个算法的代码中包含两个嵌套的循环,外层循环的迭代次数与输入规模n成正比,内层循环的迭代次数也与输入规模n成正比,那么其时间复杂度为O(n^2)。
例如,二重循环嵌套的矩阵操作。
4.计算指数时间复杂度:如果一个算法的代码中包含递归调用,且递归次数与输入规模n成正比,那么其时间复杂度可能是指数级别的,如O(2^n)。
例如,求解斐波那契数列的递归算法。
计算空间复杂度是用来衡量算法所需的额外存储空间随输入规模增长而增长的趋势。
以下是计算空间复杂度的一些常见方法:1.计算固定空间复杂度:如果一个算法的代码所需的额外存储空间不随输入规模变化,那么它的空间复杂度为O(1)。
例如,仅需要几个变量来存储中间计算结果的操作。
2.计算线性空间复杂度:如果一个算法的代码所需的额外存储空间随输入规模n成正比,那么它的空间复杂度为O(n)。
例如,需要创建一个数组或链表来存储输入数据的操作。
3.计算递归空间复杂度:如果一个算法中使用了递归调用,那么每个递归调用都需要创建一个新的函数调用栈帧,因此空间复杂度可能是O(n),其中n是递归的深度。
例如,递归求解二叉树问题的操作。
在进行时间复杂度和空间复杂度的计算时,可以按照以下步骤进行:1.根据算法的代码,找出其中的关键代码块,例如循环、递归等。
时间的复杂度详解
时间的复杂度详解时间复杂度是衡量算法运行时间的一种度量方式,用大O符号(O)来表示。
它描述了算法所需的计算步骤数随问题规模的增长率。
在计算机科学中,时间复杂度主要关注的是算法在处理大规模问题时所需的时间。
为了更好地理解时间复杂度,我们需要先了解一些基本概念。
1.基本操作在算法中,基本操作是指运算的最小单位。
它们通常是赋值、比较、运算、访问数组元素等。
基本操作的数量是衡量算法运行时间的关键。
2.渐近表示法时间复杂度使用大O符号来表示,表示算法运行时间的上界。
例如,如果一个算法的时间复杂度为O(n),意味着算法的运行时间最多是输入规模n的某个常数倍。
大O符号忽略了低阶项和常数项,只关注随问题规模增长最快的那一项。
下面我们来详细讨论几个常见的时间复杂度。
1.常数时间复杂度O(1)无论输入规模大小,常数时间复杂度的算法都具有固定的运行时间。
例如,访问数组元素或者执行一个赋值语句。
常数时间复杂度通常是最理想的情况,但在实际中很难实现。
2.线性时间复杂度O(n)线性时间复杂度表示随着输入规模n的增长,算法的运行时间也会线性增长。
例如,遍历一个数组或者链表中的所有元素。
每个元素都需要进行常数次的基本操作,所以总的时间复杂度为O(n)。
3.对数时间复杂度O(log n)对数时间复杂度通常出现在数据规模减半的情况下。
例如,在二分查找算法中,每次查找都可以将问题规模减半。
对数时间复杂度的算法是非常高效的,因为随着问题规模的增长,算法的运行时间只会以对数方式增长。
4.平方时间复杂度O(n^2)平方时间复杂度表示随着输入规模n的增长,算法的运行时间会呈平方级别增长。
例如,嵌套循环中的每次迭代都需要进行常数次的基本操作。
平方时间复杂度的算法常常效率较低,通常不适用于处理大规模问题。
5.指数时间复杂度O(2^n)指数时间复杂度表示随着输入规模n的增长,算法的运行时间呈指数级别增长。
例如,在TSP(旅行商问题)的暴力求解方法中,对于每个城市,旅行商都需要选择下一个未访问的城市,因此总的时间复杂度会呈指数级别增长。
算法的时间复杂度和空间复杂度简单理解
算法的时间复杂度和空间复杂度简单理解时间复杂度是指执⾏算法所需要的计算⼯作量;⽽空间复杂度是指执⾏这个算法所需要的内存空间。
(算法的复杂性体现在运⾏该算法时的计算机所需资源的多少上,计算机资源最重要的是时间和空间(即寄存器)资源,因此复杂度分为时间和空间复杂度在描述算法复杂度时,经常⽤到o(1), o(n), o(logn), o(nlogn)来表⽰对应算法的时间复杂度。
这⾥进⾏归纳⼀下它们代表的含义:这是算法的时空复杂度的表⽰。
不仅仅⽤于表⽰时间复杂度,也⽤于表⽰空间复杂度。
⼀个算法的优劣主要从算法的所需时间和所占⽤的空间两个⽅⾯衡量。
⼀般空间利⽤率⼩的,所需时间相对较长。
所以性能优化策略⾥⾯经常听到空间换时间,时间换空间这样说法 O后⾯的括号中有⼀个函数,指明某个算法的耗时/耗空间与数据增长量之间的关系。
其中的n代表输⼊数据的量。
1. ⽐如时间复杂度为O(n),就代表数据量增⼤⼏倍,耗时也增⼤⼏倍。
⽐如常见的遍历算法。
int x=1; while (x <n){ x++; } list.contains()⽅法,系统会对list中的每个元素e调⽤o.equals(e),因此⽤时间复杂度表⽰是O(n) 该算法执⾏次数是如果n=10, 执⾏次数就是10,n是个变量,⽤时间复杂度表⽰是O(n)。
2. 再⽐如时间复杂度O(n^2),就代表数据量增⼤n倍时,耗时增⼤n的平⽅倍,这是⽐线性更⾼的时间复杂度。
⽐如冒泡排序,就是典型的O(n^2)的算法,对n个数排序,需要扫描n×n次。
for (i = 0; i < n; i++){ for (j = 0; j < n; j++){ //... } } 如果两层循环,该算法for循环,最外层循环每执⾏⼀次,内层循环都要执⾏n次,执⾏次数是根据n所决定的,最⼤时间复杂度是O(n^2),如果内层循环在某种场景⼀次就跳出,其实也可以退化成o(n), 通常我们计算时间复杂度都是计算最多情况.由此类推,如果是三层循环,最⼤时间复杂度就是 O(n^3).⽐如冒泡、选择等等 3. O(1)就是最低的时空复杂度了,也就是耗时/耗空间与输⼊数据⼤⼩⽆关,⽆论输⼊数据增⼤多少倍,耗时/耗空间都不变。
算法基础(1)之递归、时间空间复杂度
算法基础(1)之递归、时间空间复杂度参考⽬录:我的笔记:递归(recursion)递归是⼀种很常见的计算编程⽅法,现在通过阶乘案例来学习递归demo1:function factorial(num) {if(num === 1) return num;return num * factorial(num - 1); // 递归求n的阶乘,会递归n次,每次递归内部计算时间是常数,需要保存n个调⽤记录,复杂度 O(n)}const view = factorial(100);console.time(1);console.log(view); // 1: 3.568msconsole.timeEnd(1);递归可能会造成栈溢出,在程序执⾏中,函数通过栈(stack——后进先出)这种数据实现的,每当进⼊⼀个函数调⽤,栈就会增加⼀层栈帧,每次函数返回,栈就会减少⼀层栈帧。
由于栈的⼤⼩不是⽆限的,所以,递归调⽤的次数过多,就会导致栈溢出(stack overflow)。
demo2:尾递归// 如果改为尾递归,只需要保留⼀个调⽤记录,复杂度为O(1)function factorial01(n, tntal) {if(n === 1) return tntalreturn factorial(n - 1, n * tntal) // 把每⼀步的乘积传⼊到递归函数中,每次仅返回递归函数本⾝,total在函数调⽤前就会被计算,不会影响函数调⽤}console.time(2)console.log(factorial01(5, 1)) // 120console.timeEnd(2) // 2: 0.14404296875ms栈帧每⼀个栈帧对应着⼀个未运⾏完的函数,栈帧中保存了该函数的返回地址和局部变量。
栈帧也叫过程活动记录,是编译器⽤来实现过程/函数调⽤的⼀种数据结构。
从逻辑上讲,栈帧就是⼀个函数执⾏的环境:函数参数、函数的局部变量、函数执⾏完后返回到哪⾥等。
算法复杂度——时间复杂度和空间复杂度
1.时间复杂度(1)时间频度一个算法执行所耗费的时间,从理论上是不能算出来的,必须上机运行测试才能知道。
但我们不可能也没有必要对每个算法都上机测试,只需知道哪个算法花费的时间多,哪个算法花费的时间少就可以了。
并且一个算法花费的时间与算法中语句的执行次数成正比例,哪个算法中语句执行次数多,它花费时间就多。
一个算法中的语句执行次数称为语句频度或时间频度。
记为T(n)。
(2)时间复杂度在刚才提到的时间频度中,n称为问题的规模,当n不断变化时,时间频度T(n)也会不断变化。
但有时我们想知道它变化时呈现什么规律。
为此,我们引入时间复杂度概念。
一般情况下,算法中基本操作重复执行的次数是问题规模n的某个函数,用T(n)表示,若有某个辅助函数f(n),使得当n趋近于无穷大时,T(n)/f(n)的极限值为不等于零的常数,则称f(n)是T(n)的同数量级函数。
记作T(n)=O(f(n)),称O(f(n)) 为算法的渐进时间复杂度,简称时间复杂度。
在各种不同算法中,若算法中语句执行次数为一个常数,则时间复杂度为O(1),另外,在时间频度不相同时,时间复杂度有可能相同,如 T(n)=n2+3n+4与T(n)=4n2+2n+1它们的频度不同,但时间复杂度相同,都为O(n2)。
按数量级递增排列,常见的时间复杂度有:常数阶O(1),对数阶O(log2n),线性阶O(n), 线性对数阶O(nlog2n),平方阶O(n2),立方阶O(n3),...,k次方阶O(nk),指数阶O(2n)。
随着问题规模n的不断增大,上述时间复杂度不断增大,算法的执行效率越低。
2、空间复杂度与时间复杂度类似,空间复杂度是指算法在计算机内执行时所需存储空间的度量。
记作: S(n)=O(f(n)) 我们一般所讨论的是除正常占用内存开销外的辅助存储单元规模。
讨论方法与时间复杂度类似,不再赘述。
(3)渐进时间复杂度评价算法时间性能主要用算法时间复杂度的数量级(即算法的渐近时间复杂度)评价一个算法的时间性能。
数据结构与算法(一)时间复杂度、空间复杂度计算
数据结构与算法(⼀)时间复杂度、空间复杂度计算⼀、时间复杂度计算1、时间复杂度的意义复杂度分析是整个算法学习的精髓,只要掌握了它,数据结构和算法的内容基本上就掌握了⼀半1. 测试结果⾮常依赖测试环境2. 测试结果受数据规模的影响很⼤所以,我们需要⼀个不⽤具体的测试数据来测试,就可以粗略地估计算法的执⾏效率的⽅法,即时间、空间复杂度分析⽅法。
2、⼤ O 复杂度表⽰法1)、可以将计算时间复杂度的⽅式和计算代码执⾏次数来进⾏类别int cal(int n) {int sum = 0;int i = 1;for (; i <= n; ++i) {sum = sum + i;}return sum;}第 2、3 ⾏代码分别需要 1 个 unit_time 的执⾏时间,第 4、5 ⾏都运⾏了 n 遍,所以需要 2n * unit_time 的执⾏时间,所以这段代码总的执⾏时间就是(2n+2) * unit_time。
可以看出来,所有代码的执⾏时间 T(n) 与每⾏代码的执⾏次数成正⽐。
2)、复杂⼀点的计算int cal(int n) { ----1int sum = 0; ----2int i = 1; ----3int j = 1; ----4for (; i <= n; ++i) { ----5j = 1; ----6for (; j <= n; ++j) { ----7sum = sum + i * j; ----8} ----9} ----10} ----11T(n) = (2n^2+2n+3)unit_timeT(n)=O(f(n))⼤ O 时间复杂度实际上并不具体表⽰代码真正的执⾏时间,⽽是表⽰代码执⾏时间随数据规模增长的变化趋势,所以,也叫作渐进时间复杂度(asymptotic time complexity),简称时间复杂度2、时间复杂度计算法则1. 只关注循环执⾏次数最多的⼀段代码2. 加法法则:总复杂度等于量级最⼤的那段代码的复杂度如果 T1(n)=O(f(n)),T2(n)=O(g(n));那么 T(n)=T1(n)+T2(n)=max(O(f(n)), O(g(n))) =O(max(f(n), g(n))).3. 乘法法则:嵌套代码的复杂度等于嵌套内外代码复杂度的乘积T(n) = T1(n) * T2(n) = O(n*n) = O(n2)3、常见的是时间复杂度复杂度量级(递增)排列公式常量阶O(1)对数阶O(logn)线性阶O(n)线性对数阶O(nlogn)平⽅阶、⽴⽅阶...K次⽅阶O(n2),O(n3),O(n^k)指数阶O(2^n)阶乘阶O(n!)①. O(1):代码的执⾏时间和n没有关系,⼀般情况下,只要算法中不存在循环语句、递归语句,即使有成千上万⾏的代码,其时间复杂度也是Ο(1);②. O(logn)、O(nlogn)i=1;while (i <= n) {i = i * 2;}通过 2x=n 求解 x 这个问题我们想⾼中应该就学过了,我就不多说了。
空间复杂度的计算
空间复杂度的计算空间复杂度是用来评估算法使用的额外存储空间与问题规模的关系。
它是衡量算法空间利用率的一个指标,可以帮助我们判断算法在内存使用方面的优劣。
在计算空间复杂度时,我们主要关注算法在运行过程中所占用的额外空间,而不是算法本身的输入空间。
在计算空间复杂度时,我们需要考虑算法中使用的额外数据结构、变量及其大小。
下面将介绍几种常见的计算空间复杂度的方法。
1.常量空间复杂度:有些算法的空间复杂度是固定的,与问题规模无关,即常量空间复杂度。
例如,一个简单的赋值语句,或者一个简单的条件表达式,它们的空间占用是固定的,不随问题规模的增加而增加。
这种算法的空间复杂度可以表示为O(1)。
2.线性空间复杂度:如果一个算法的空间占用是根据问题规模线性增加的,那么它的空间复杂度可以表示为O(n),其中n为问题规模。
这种算法通常需要使用数组、列表或栈等数据结构来保存数据。
例如,一个循环语句中的数组存储,其空间占用是随着问题规模的增加而线性增加的。
3.平方空间复杂度:如果一个算法的空间占用是根据问题规模的平方增加的,那么它的空间复杂度可以表示为O(n^2)。
这种算法通常需要使用二维数组或多个嵌套的循环来保存数据。
例如,一个嵌套的循环中的二维数组存储,其空间占用是随着问题规模的增加而平方增加的。
4.指数空间复杂度:如果一个算法的空间占用是按照指数规模增加的,那么它的空间复杂度可以表示为O(2^n)。
这种算法通常需要使用递归或者回溯等指数级别的算法来保存数据。
例如,一个指数级别的递归算法,每次递归调用都会产生指数级别的新变量。
除了以上几种常见的空间复杂度,还有一些特殊情况需要考虑。
例如,当一个算法需要使用动态分配内存时,其空间复杂度与使用的动态分配内存的数量和大小有关。
这种情况下,需要对动态分配内存的大小进行分析,以确定空间复杂度。
另外,需要注意的是,空间复杂度并不是一个精确的值,而是一个上界估计。
空间复杂度只是一个表示算法空间占用的数量级估算,忽略了常数因子和小规模问题带来的额外开销。
常用算法时间复杂度的计算方法
常⽤算法时间复杂度的计算⽅法1. 时间复杂度 时间复杂度是指程序运⾏从开始到结束所需要的时间。
时间复杂度的计算⼀般⽐较⿇烦,故在数据结构的研究中很少提及时间复杂度。
为了便于⽐较同⼀个问题的不同算法,通常做法是,从算法中选取⼀种对于所研究的问题来说是基本操作的原操作,以该基本操作重复执⾏的次数做为算法的时间量度。
基本操作应是其重复执⾏次数和算法时间成正⽐的原操作,多数情况下它是最深层循环内的语句中的操作。
算法的执⾏次数还要随输⼊集有关,此时要考虑所有可能输⼊数据的期望值,此时的算法时间复杂度叫平均时间复杂度。
有事平均时间复杂度难以确定,此时分析最坏情况下算法的⼀个上界,此时称为最坏时间复杂度。
2. 时间复杂度的表⽰⽅法 设解决⼀个问题的规模为n,基本操作被重复执⾏次数是n的⼀个函数f(n),则时间复杂度可记作: T(n)=O(f(n)) 它表⽰随着问题规模n的增长,算法执⾏时的增长率和f(n)的增长率相同。
其中T(n)叫算法的渐进时间复杂度,简称时间复杂度。
算法的时间复杂度考虑的只是对于问题规模n的增长率,则在难以精确计算的情况下,只需考虑它关于n的增长率或阶即可。
例如 for(i=2;i<=n;++i) for(j=2;j<=i-1;++j) { ++x; a[i,j]=x; } 其中++x语句频度为:1+2+3+…+n-2=(n-1)(n-2)/2=(n2-3n+2)/2故算法的时间复杂度可表⽰为:T(n)=O(n2)3. 时间复杂度的计算⽅法 时间复杂的推导⽅法⼀般如下: 第⼀步:⽤常数1取代运⾏时间中的所有加法常数。
第⼆步:在修改后的运⾏次数函数中,只保留最⾼阶项。
第三步:如果最⾼阶项存在且不是1,则去除与这个项相乘的常数。
时间复杂度⼀般分为以下⼏种,分别是: (1)常数阶⾸先顺序结构的时间复杂度。
main(){int sum=0,n=100;sum=(1+n)*n/2;printf(“%d”,sum);}算法的时间复杂度为O(1)。
详解时间复杂度计算公式(附例题细致讲解过程)
详解时间复杂度计算公式(附例题细致讲解过程)摘要:一、时间复杂度概念介绍1.定义2.重要性二、常见时间复杂度分类1.O(1)2.O(log n)3.O(n)4.O(n^2)5.O(n^3)6.O(2^n)三、时间复杂度计算方法1.增长率和指数级别2.常数阶、对数阶、线性阶、平方阶和立方阶四、例题讲解1.求解斐波那契数列的时间复杂度2.求解排序算法的时间复杂度3.求解二分查找算法的时间复杂度五、时间复杂度优化方法1.优化算法策略2.数据结构选择六、总结与实践应用1.掌握时间复杂度概念2.熟练运用常见时间复杂度分类3.提高算法分析和优化能力正文:一、时间复杂度概念介绍1.定义时间复杂度是用来估计算法运行时间的一个指标,通常用大O符号(O)表示。
它描述了算法在最坏情况下的运行时间增长速度,是评价算法效率的重要标准。
2.重要性掌握时间复杂度概念有助于我们:(1)预测算法性能:通过比较不同算法的时间复杂度,预测算法在实际应用中的性能表现。
(2)优化算法:根据时间复杂度分析,找出算法中的瓶颈,有针对性地进行优化。
二、常见时间复杂度分类1.O(1):常数阶,代表算法运行时间与输入规模无关,如访问数组元素、哈希表查找等。
2.O(log n):对数阶,代表算法运行时间与输入规模的对数成正比,如二分查找、红黑树查找等。
3.O(n):线性阶,代表算法运行时间与输入规模成正比,如遍历数组或列表、线性查找等。
4.O(n^2):平方阶,代表算法运行时间与输入规模的平方成正比,如冒泡排序、插入排序等。
5.O(n^3):立方阶,代表算法运行时间与输入规模的立方成正比,如选择排序、希尔排序等。
6.O(2^n):指数阶,代表算法运行时间随输入规模呈指数级增长,如解决旅行商问题(TSP)等。
三、时间复杂度计算方法1.增长率和指数级别:通过观察算法运行时间与输入规模的关系,判断时间复杂度。
如增长率恒定为k,则时间复杂度为O(k)。
2.常数阶、对数阶、线性阶、平方阶和立方阶:根据算法运行时间与输入规模的具体关系,确定时间复杂度类别。
【数据结构】时间复杂度和空间复杂度计算
【数据结构】时间复杂度和空间复杂度计算时间复杂度AND空间复杂度专项时间维度:是指执⾏当前算法所消耗的时间,我们通常⽤「时间复杂度」来描述。
空间维度:是指执⾏当前算法需要占⽤多少内存空间,我们通常⽤「空间复杂度」来描述。
时间复杂度⼀个算法花费的时间与算法中语句的执⾏次数成正⽐例,哪个算法中语句执⾏次数多,它花费时间就多。
⼀个算法中的语句执⾏次数称为语句频度或时间频度。
记为 T(n)。
常见的算法时间复杂度由⼩到⼤依次为:Ο(1)<Ο(log2n)<Ο(n)<Ο(nlog2n)<Ο(n2)<Ο(n3)<Ο(nk)<Ο(2n) ,随着问题规模 n 的不断增⼤,上述时间复杂度不断增⼤,算法的执⾏效率越低常见的时间复杂度:常见的时间复杂度:常数阶 O(1)对数阶 O(log2n)线性阶 O(n)线性对数阶 O(nlog2n)平⽅阶 O(n^2)⽴⽅阶 O(n^3)k 次⽅阶 O(n^k)指数阶 O(2^n)常见阶数串讲常数阶 O(1)没有循环结构,代码上万⾏都可以,消耗并不伴随某个的增长⽽增长,都是O(1)对数阶O(log2n)举个例⼦int n=1000;int i=1;while(i<=n){i=i*2;}cout<<"啦啦啦啦i="<<i<<endl;看在while循环中执⾏了多少次:while终⽌条件是i>n的时候,即当2的x次⽅等于n时结束循环,那么显然x=log2n。
也就是说while循环执⾏了log2n次后就结束了,那么这个算法的时间复杂度就是log2n。
从这个例⼦可以看出,如果将循环改成i=i*3;那么复杂度⾃然就变成了log3n。
线性阶O(n)现在你已经基本⼊门啦,我们直接上例⼦,线性阶很好理解,就是在循环中变量增长从倍数变成了单个增长。
int n=1000;int i=1;while(i<=n){i++;}cout<<"啦啦啦啦i="<<i<<endl;显然i需要增加n次才可以执⾏结束,故时间复杂度为O(n)线性对数阶O(nlogN)套娃!外层循环执⾏n次,内部循环需要执⾏logN次,那么⼀共就是n*logN啦,故时间复杂度为O(nlogN)。
算法复杂度的计算方法
算法复杂度的计算方法算法复杂度的计算方法什么是算法复杂度算法复杂度是衡量一个算法执行效率的指标,常用来评估算法的时间和空间消耗情况。
它能够帮助我们选择更加高效的算法,在解决问题时更有效地利用计算资源。
时间复杂度常见的时间复杂度•O(1):常数时间复杂度,表示算法的执行时间是固定的,不随问题规模的增加而变化。
例如,查找数组中某个元素的索引。
•O(logn):对数时间复杂度,表示算法的执行时间随问题规模的增加而呈对数增长。
例如,二分查找算法。
•O(n):线性时间复杂度,表示算法的执行时间随问题规模的增加而呈线性增长。
例如,遍历数组求和。
•O(n^2):平方时间复杂度,表示算法的执行时间随问题规模的增加而呈平方增长。
例如,多次嵌套循环遍历二维数组。
•O(2^n):指数时间复杂度,表示算法的执行时间随问题规模的增加而呈指数增长。
例如,解决旅行商问题的暴力穷举法。
如何计算时间复杂度通常情况下,通过分析算法中的循环次数或者递归调用次数,可以推导出算法的时间复杂度。
以下是一些常见的情况和计算方法:•单条语句执行:如果算法中只包含一条语句,那么它的时间复杂度为O(1),即常数时间复杂度。
•顺序执行:如果算法中包含多条语句,并且按照顺序执行,那么算法的时间复杂度取决于耗时最长的那条语句的复杂度。
•循环语句:根据循环的次数和循环体内的代码复杂度,可以推导出循环语句的时间复杂度。
•递归调用:递归算法的时间复杂度和递归调用的次数以及每次调用的复杂度有关。
空间复杂度常见的空间复杂度•O(1):常数空间复杂度,表示算法的额外空间消耗是固定的,不随问题规模的增加而变化。
•O(n):线性空间复杂度,表示算法的额外空间消耗随问题规模的增加而线性增长。
•O(n^2):平方空间复杂度,表示算法的额外空间消耗随问题规模的增加而平方增长。
•O(2^n):指数空间复杂度,表示算法的额外空间消耗随问题规模的增加而指数增长。
如何计算空间复杂度空间复杂度的计算方法与时间复杂度类似,但要注意算法中需要额外使用的空间。
常见排序算法及对应的时间复杂度和空间复杂度
常见排序算法及对应的时间复杂度和空间复杂度转载请注明出处:(浏览效果更好)排序算法经过了很长时间的演变,产⽣了很多种不同的⽅法。
对于初学者来说,对它们进⾏整理便于理解记忆显得很重要。
每种算法都有它特定的使⽤场合,很难通⽤。
因此,我们很有必要对所有常见的排序算法进⾏归纳。
排序⼤的分类可以分为两种:内排序和外排序。
在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使⽤外存,则称为外排序。
下⾯讲的排序都是属于内排序。
内排序有可以分为以下⼏类: (1)、插⼊排序:直接插⼊排序、⼆分法插⼊排序、希尔排序。
(2)、选择排序:直接选择排序、堆排序。
(3)、交换排序:冒泡排序、快速排序。
(4)、归并排序 (5)、基数排序表格版排序⽅法时间复杂度(平均)时间复杂度(最坏)时间复杂度(最好)空间复杂度稳定性复杂性直接插⼊排序O(n2)O(n2)O(n2)O(n2)O(n)O(n)O(1)O(1)稳定简单希尔排序O(nlog2n)O(nlog2n)O(n2)O(n2)O(n)O(n)O(1)O(1)不稳定较复杂直接选择排序O(n2)O(n2)O(n2)O(n2)O(n2)O(n2)O(1)O(1)不稳定简单堆排序O(nlog2n)O(nlog2n)O(nlog2n)O(nlog2n)O(nlog2n)O(nlog2n)O(1)O(1)不稳定较复杂冒泡排序O(n2)O(n2)O(n2)O(n2)O(n)O(n)O(1)O(1)稳定简单快速排序O(nlog2n)O(nlog2n)O(n2)O(n2)O(nlog2n)O(nlog2n)O(nlog2n)O(nlog2n)不稳定较复杂归并排序O(nlog2n)O(nlog2n)O(nlog2n)O(nlog2n)O(nlog2n)O(nlog2n)O(n)O(n)稳定较复杂基数排序O(d(n+r))O(d(n+r))O(d(n+r))O(d(n+r))O(d(n+r))O(d(n+r))O(n+r)O(n+r)稳定较复杂图⽚版①插⼊排序•思想:每步将⼀个待排序的记录,按其顺序码⼤⼩插⼊到前⾯已经排序的字序列的合适位置,直到全部插⼊排序完为⽌。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
因此要求F(n),只要对这个二阶方阵求n - 1次方,最后取结果方阵第一行第 一列的数字就可以了。看起来有点儿化简为繁的感觉,但关键点在于,幂运算 是可以二分加速的。设有一个方阵a,利用分治法求a的n次方,有:
If x 为偶数 If x为奇数
可见复杂度满足T(n) = T(n / 2) + O(1),要求得n次方,我们先求得n/2次 方,再把n/2的结果平方一下。如果把求n次方的问题看成一个大问题,把 求n/2看成一个较小的问题。这种把大问题分解成一个或多个小问题的思 路我们称之为分治法。这样求n次方就只需要logn次运算了。 因此整个算法的时间复杂度是O(log n),空间复杂度是O(1)。
( c < log2N < n < n log2N < n^2 < n^3 < 2^n < 3^n < n!)
对于同一个问题,所采用的算法不同,其所需的时间复 杂度和空间复杂度的差别也是很大的,下面以Fibonacci数 列为例
• Fibonacci数列
n0 1 F ( n) 1 n 1 F ( n 1) F ( n 2) n 1
时间复杂度和空间复杂度
1.算法的执行时间和语句频度 在已证明算法正确性的前提下,评价算法的好坏主要是关 注算法在时间和空间上性能的优劣。 算法时间性能的分析是通过计算算法时间复杂度实现的, 其关键就是计算算法的执行时间。一个算法的执行时间,就是 算法中每条语句的执行时间的总和。 但是在算法实际运行过程中,每次执行所耗费的时间会受到 诸如问题规模、输入特性和具体硬件环境等各种外界因素的影 响,想得到一个绝对准确的执行时间,几乎不可能。为此,在 计算算法执行时间时,一般都忽略硬件及环境因素,并且假设 每次执行时,硬件条件和环境条件都是完全一致的,每条语句 执行一次所需的时间均是单位时间。
3.迭代法
当算法中包含递归函数时!其时间复杂度也会被转化为一个递归方程,上述两种 方法此时不再适用,递归方程的形式多种多样,其求解方法也是不一而足,比较常 用是迭代法,其基本步骤是迭代地展开递归方程的右端,使之成为一个非递归的和 式,然后通过对和式的估计来得到时间复杂度T(n)。
例1
几个需要注意的问题
例1
i=s=0; While(s<n) {i ++; s=s+i ;}
例2
X=91; y=100; While(y>0) If(x>100) {x-=10; y--;} else x++;
由分析可知 每循环11 次,y的值发生一次变化,y共 需共变化 100 次, 所以f(n)=100*11, 则该算法的执行时间是一个与问题规模n无关的常数,它不随着问题规模 n 的 增加而增长。即使算法中有上千条语句,其执行时间也不过是一个较大的常数, 因此,该算法的时间复杂度为常数阶,记为T(n)=O(1)。
记T(n)为计算fib(n)的时间复杂度 T(n)=T(n-1)+T(n-2),
Fibonacci数的通项公式是: 很容易得到T(n) = (1.618 ^ n)(就是黄金分割)。空间复杂度 取决于递归的深度,显然是O(n)。
2.递推法
•
•
//非递归求斐波那契数列 public int uRFibonacci(int n) {
int x=1; int y=1; int tmp; for(int i=2;i<n;i++){ tmp=x; x=y; }
• • • • • • • • • • •
y=y+tmp;
return y;
}
显然时间复杂度是O(n),空间复杂度是O(1)
3.矩阵法
计算Fibonacci数精确值的最快的方法应该就是矩阵法。我们把Fibonacci数列 中相邻的两项:F(n)和F(n - 1)写成一个2x1的矩阵,然后对其进行变形,看 能得到什么:
• 1.时间复杂度为O(1)
在各种不同算法中,若算法中语句执行次数为一个常数, 则时间复杂度为O(1),时间复杂度T(n)并不是随着问题的规 模n变化的。
2. O(1)和O(2)的区别
•
根据符号O的定义易知, O(1) =O(2),用O(1)或O(2)表示同 一个函数时,差别仅在于其中的常数因子。
• 3.时间频度不相同时,时间复杂度有可能相同
时间复杂度的几种求法
在算法时间复杂度的计算中,最关键的是得出算法中最多的执行次 数。算法的执行时间绝大部分花在循环和递归上。目前常用的时间复 杂度计算方法可以归纳为如下几种。
1、求和法
当算法中语句的执行次数与某一变量有直接关系,而该变量的变化起止范围又 较为明确,则可以利用求和公式得出最大的语句频度f(n),再对其取数量级(阶) 即可。
算法中一条语句的执行时间取决于该语句的执行次数和执行一次所 需的时间。语句执行次数被称为语句频度,执行一次的时间被假设为单 位时间,因此算法的执行时间就可以看作是该算法中所有语句的语句频 度之和。
当问题规模很大时,精确的计算T(n)是很难实现而且也是没 有必要的, 对于算法时间性能的分析无需非要得到时间复杂度 T(n) 的精确值, 它的变化趋势和规律也能清楚地反映算法的时间 耗费. 基于此, 引入了渐进时间复杂度作为时间性能分析的依据, 它的含义就是: 在问题规模n趋于无穷大时算法时间复杂度 T(n) 的渐进上界,即函数T(n)的数量级阶。算法时间复杂度和渐进算 法时间复杂度在实际的算法分析过程中是不予区分的, 渐进时间 复杂度可以简称为时间复杂度,记为T(n)=O(f(n))。其中,O表示 数量级(阶)。函数f(n)一般是算法中最大的语句频度。 函数f(n)是T(n)的同数量级(阶)函数, ( C不为常数)。
对于任意指定的整数n(n>=0),计算F(n)的精确值,并分析算 法的时间、空间复杂度。
1.递归法
• //递归求斐波那契数列 • public int rFibonacci(int n){ • • if(n<=1){ • return 1; • } • return rFibonacci(n-1)+rFibonacci(n-2); • }
例2、有N个大小不等的自然数(1--N), 请将它们由 小到大排序。要求程序算法: 时间复杂度为O(n),空间复杂度为O(1)。 (华为笔试面试题)
以上算法中语句频度最大的是语句4,其频度可通过求和公式求得
所以该算法的时间复杂度为立方阶,记为O(n^3)
2、假设法
在某些较为复杂的算法中,循环结构的循环次数很难直接看出,特别 是当循环次数与循环体中的某些语句执行有联系时,语句频度的计算变 得比较困难。此时,可以先假设循环执行次数为k次 ,再对算法进行分 析 ,根据循环终止条件求出语句频度 f(n),最后求出T(n)
运行时间的准紧近界,Θ来自运行时间的上界,O运行时间的下界,Ω
2、空间复杂度 与时间复杂度类似,空间复杂度是指算法在计算机内执 行时所需存储空间的度量。记作:S(n)=O(f(n))。 一般所讨论的是除正常占用内存开销外的辅助存储单元 规模。
按数量级递增排列,常见的时间复杂度有: 常数阶O(1), 对数阶O(log2n), 线性阶O(n), 线性对数阶O(n log2N ), 平方阶O(n^2), 立方阶O(n^3), ……. , k次方阶O(n^k) , 指数阶 O(2^n), 随着问题规模 n的不断增大,上述时间复杂度不断增大, 算法的执行效率越低。
比如:T(n)=n^2+3n+4与T(n)=4n^2+2n+1它们的频度不同,但 时间复杂度相同,都为O(n^2)。
例1、 对某类特定的玻璃瓶子样品做强度测试 以确定他们从多高的高度掉下来而仍旧不碎。如 下设计这样一个实验。你有一个具有n个横档的 阶梯,并且你想找出最高的横档,能使一个瓶子 的样品那哪里下落而不被摔破。
1、二分搜索方法。时间复杂度为Log(n),但是缺点是你可能 摔破一大堆的瓶子。 2、如果主要目标是保护瓶子,从第一个横档开始让瓶子 下落,然后第二个横档,每次向上爬一个高度知道瓶子 摔破为止,这种方式只需要一个瓶子,但是可能的时间 复杂度是n。 思考题: 时间复杂度和摔破瓶子之间是个不可调和的矛盾。假设只 给你2个瓶子,描述一种找到最高安全横档的策略。