热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

时间复杂度_python数据结构与算法时间复杂度

篇首语:本文由编程笔记#小编为大家整理,主要介绍了python数据结构与算法---时间复杂度相关的知识,希望对你有一定的参考价值。 python数据结构与算法(1)---时间复杂度

篇首语:本文由编程笔记#小编为大家整理,主要介绍了python数据结构与算法---时间复杂度相关的知识,希望对你有一定的参考价值。




python数据结构与算法(1)---时间复杂度

 

一.数据结构基础

1.数据结构概念

 

就是一组数据在内存中的存储形式,也是对基本数据类型的一次封装

 

也是数据对象中数据元素之间的关系。

 

算法与数据结构的区别:

 

数据结构只是静态的描述了数据元素之间的关系

 

高效的程序需要在数据结构的基础上设计和选择算法

 

程序=数据结构+算法

 

总结:算法是为了解决实际问题而设计的,数据结构是算法需要处理的问题的载体。

 

2.抽象数据类型(ADT)

 

就是将数据类型和数据类型上的运算捆在一起,进行封装,相当于类

 

3.算法效率的衡量

实现算法程序的执行时间可以反映出算法的效率

但是单纯依靠运行的时间来比较算法的优劣不一定是客观准确的

时间复杂度:

反应算法在时间上的效率

我们假定计算机执行算法每一个基本操作的时间是固定的一个时间单位,算法对于不同的机器环境而言,确切的单位时间是不同的,但是对于算法进行多少个基本操作在规模数量级上是相同的,因此可以忽略机器环境的影响客观的反应算法的时间效率。

“大O记法”表示算法的时间效率:

计算算法的基本操作的执行次数,为g(n),使得算法处理规模为n的问题示例所用时间为T(n)=O(g(n)),则称O(g(n))为算法A的渐进时间复杂度,简称时间复杂度,记为T(n)。

理解“大O法”:对于算法的基本操作的执行次数,不用计算的太细致,最重要的是数量级和趋势,这个基本操作数量的规模函数中一些常量因子可以忽略不计。例如: 和 属于同一个数量级,他们的时间复杂度都是级。

最坏时间复杂度(主要关注):

算法完成工作最多需要多少基本操作

平均时间复杂度(比较全面):

算法完成工作平均需要多少基本操作

时间复杂度的几条基本计算规则:

(1)基本操作,只有常数项。认为时间复杂度为O(1)

(2)顺序结构,时间复杂度加法计算

(3)循环结构,时间复杂度乘法计算

(4)分支结构,时间复杂度取最大值

(5)判断一个算法的效率时,往往只需要关注数量的最高次项,其他可以忽略。

(6)没有特殊说明的情况下,分析的都是最坏时间复杂度

list内置操作的时间复杂度:

dict内置操作的时间复杂度:

常见的时间复杂度之间的关系:

 

 所消耗的时间的大小:

 

O(1)



推荐阅读
  • 提升Python编程效率的十点建议
    本文介绍了提升Python编程效率的十点建议,包括不使用分号、选择合适的代码编辑器、遵循Python代码规范等。这些建议可以帮助开发者节省时间,提高编程效率。同时,还提供了相关参考链接供读者深入学习。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 学习SLAM的女生,很酷
    本文介绍了学习SLAM的女生的故事,她们选择SLAM作为研究方向,面临各种学习挑战,但坚持不懈,最终获得成功。文章鼓励未来想走科研道路的女生勇敢追求自己的梦想,同时提到了一位正在英国攻读硕士学位的女生与SLAM结缘的经历。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 流程控制之分支结构
    一. 什么是流程控制流程控制是程序代码执行的顺序。二. 事物执行流程1)顺序结构从上往下依次执行,我们之前所编写的代码都属于该结构2)分支结构事物的 ... [详细]
  • 那你就是学的c语言,跟我学c语言
    本文目录一览:1、如何学习C语言?2、新手如何 ... [详细]
  • Python循环语句代码逐行详解:while、for、break和continue
    来源:大数据DT本文约3200字,建议阅读9分钟循环语句是指重复执行同一段代码块,通常用于遍历集合或者累加计算。Python中的循环语句有 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 本文介绍了游戏开发中的人工智能技术,包括定性行为和非定性行为的分类。定性行为是指特定且可预测的行为,而非定性行为则具有一定程度的不确定性。其中,追逐算法是定性行为的具体实例。 ... [详细]
  • 本文介绍了PhysioNet网站提供的生理信号处理工具箱WFDB Toolbox for Matlab的安装和使用方法。通过下载并添加到Matlab路径中或直接在Matlab中输入相关内容,即可完成安装。该工具箱提供了一系列函数,可以方便地处理生理信号数据。详细的安装和使用方法可以参考本文内容。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
author-avatar
Min2502857657_377
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有