时间复杂度几个概念

T(N) = O(f(N))(念做大O),含义:T(N)的增长率小于等于f(N)的增长率。理解为,N趋于无穷大,T(N) <= f(N)。若T(N)的增长率恒小于f(N),则可记为T(N) = o(f(N))(念做小o)。

T(N) = Ω(g(N))(念做omega),含义:T(N)的增长率大于等于g(N)的增长率。理解为,N趋于无穷大,T(N)>=g(N)。

当T(N) = O(h(N)) 且 T(N) = Ω(g(N)),则T(N) = Θ(h(N))(念theta)。

法则1:

如果T1(N) = O(f(N))且T2(N) = O(g(N)),那么

1)T1(N) + T2(N) = max(O(f(N)), O(g(N)))

2)T1(N) * T2(N) = O(f(N) * g(N))

法则2:

如果T(N)是一个k次多项式,则T(N)=Θ(Nk)

法则3:

对于任意常熟k,logkN = O(N)。(这个法则用的比较多,说明每个循环若都是logN,则套几次循环都比O(N)快)

时间: 2024-09-26 20:19:20

时间复杂度几个概念的相关文章

算法的复杂度包括时间复杂度和空间复杂度分别如何计算?

一 .时间复杂度 一.概念 时间复杂度是总运算次数表达式中受n的变化影响最大的那一项(不含系数) 比如:一般总运算次数表达式类似于这样: a*2n+b*n3+c*n2+d*n*lg(n)+e*n+f a ! =0时,时间复杂度就是O(2n); a=0,b<>0 =>O(n3); a,b=0,c<>0 =>O(n2)依此类推 例子: (1) for(i=1;i<=n;i++) //循环了n*n次,当然是O(n2) for(j=1;j<=n;j++) s++;

数据结构时间复杂度讲解与练习

一个算法中的语句执行次数称为语句频度或时间频度,记为T(n).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)) 为算法的渐进时间复杂度. 时间频

精简版时间复杂度与空间复杂度(五分钟掌握)

前言 一个算法的优劣好坏,会决定一个程序运行的时间.空间.也许当小数据量的时候,这种影响并不明显,但是当有巨量数据的时候,算法的好坏带来的性能差异就会出天差地别.可以说直接影响了一个产品的高度和广度.每个程序员都想用最优的算法解决问题,我们期待自己写出的代码是简洁.高效的.但是如何评判一个算法的好坏呢?时间复杂度和空间复杂度就是一个很好的标准. 1. 时间复杂度 1.1 概念 执行算法所需要的计算工作量 1.2 基本执行次数T(n) 根据计算,得出的该算法在输入数据量为n时的,实际执行次数 1.

二 线性表

一. 线性表的几种形式: 1.线性表是最常用且最简单的一种数据结构. 线性表中元素的个数n定义为线程表的长度,n= 0时称为空表. 2. 线性表的顺序表示指的是用一组地址连续的存储单元依次存储线性表的数据元素. 这种顺序存储结构的线性表为顺序表. 线性表的特点: 优点是:可以随机存取的存储结构 缺点是:插入和删除时间复杂度高,主要耗费在移动元素上. 时间复杂度O(n).      数组 3.线性表的链式表示和实现  [字典,集合] 链式表是一组任意的存储单元存储线性表的数据元素(这组存储单元可以

数据结构和算法一(基础知识)

一.数据结构与算法基础知识 从广义上讲,数据结构就是指一组数据的存储结构.算法就是操作数据的一组方法. 从狭义上讲,就是指某些著名的数据结构和算法,比如队列.栈.堆.二分查找.动态规划等. 数据结构和算法是相辅相成的,数据结构为算法服务,算法要作用在特定的数据结构之上. 数据结构思维导图 基础数据结构:数组.链表.栈.队列.散列表.二叉树.堆.跳表.图.Trie树 基础算法:地柜.排序.二分查找.搜索.哈希算法.贪心算法.分治算法.回溯算法.动态规划.字符串匹配算法 二.时间复杂度和空间复杂度

一 数据结构的概念,时间复杂度和空间复杂度

一. 什么是数据结构: 对到底什么是数据结构这个概念,一直有很多不同的解释,也有许多不同的争论,这里只代表了我个人的认识. 数据结构:我们如何把现实中大量而复杂的问题以特定的数据类型和特定的存储结构保存到主存储器(内存)中,以及在此基础上为实现某 个功能(比如查找某个元素,删除某个元素等)而执行的相应操作,这个相应的操作也叫做算法. 1.算法的实现是依据不同的数据结构的. 2.算法:是对特定问题求解步骤的一种描述,以下特征:有穷性,确定性,可行性,输入和输出: 二. 时间复杂度和空间复杂度: (

[BS]初学数据结构的几个基本概念以及时间复杂度的分析

几个基本概念: 数据,数据元素,数据项,数据结构 数据(data):数据是对客观信息的一种描述,它是由能被计算机识别与处理的数值.字符等符号构成的集合.含义较为广泛,意会即可. 数据元素(data element):数据元素是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理. 数据项(data item):博主认为可以和数据元素参照理解.在遇到实际问题时我们再做分析. 数据结构(data structures):数据结构分为数据的逻辑结构和数据的物理结构.逻辑结构是面向我们所要研究的

时间复杂度和空间复杂度的概念

算法复杂度 分为时间复杂度和空间复杂度.其作用: 时间复杂度是度量算法执行的时间长短:而空间复杂度是度量算法所需存储空间的大小. 时间复杂度 1.时间频度 一个算法执行所耗费的时间,从理论上是不能算出来的,必须上机运行测试才能 知道.但我们不可能也没有必要对每个算法都上机测试,只需知道哪个算法花费的时间多,哪个算法花费的时间少就可以了.并且一个算法花费的时间与算法中语句 的执行次数成正比例,哪个算法中语句执行次数多,它花费时间就多.一个算法中的语句执行次数称为语句频度或时间频度.记为T(n).

时间复杂度的概念以及计算

老规矩, 先看看维基定义: The time complexity of an algorithm quantifies the amout of time taken by an algorithm to run as function. The complexity of an algorithm is commonly expressed using big O notation, which excludes coefficients and lower order terms. 算法的