首页 / 知识
Python数据结构的时间复杂性
2023-11-12 13:38:00
1.让我们了解大O符号的含义是什么?
在算法中执行许多操作。这些操作可能包括遍历集合,复制项目或整个集合,将项目追加到集合中,在集合的开始或结尾处插入项目,删除项目或更新集合中的项目。
Big-O衡量算法运算的时间复杂度。它测量算法计算所需运算所需的时间。尽管我们也可以测量空间复杂度(算法占用多少空间),但本文将重点介绍时间复杂度。
用最简单的术语来说,BigO表示法是一种基于输入大小(称为n)来衡量操作性能的方法。
2.BigO表示法有何不同?
我们需要熟悉许多常见的BigO符号。
让我们考虑n为输入集合的大小。就时间复杂度而言:
O(1):无论您的集合有多大,执行操作所花费的时间都是恒定的。这是恒定的时间复杂度符号。这些操作尽可能快。例如,检查集合内部是否有任何项目的操作是O(1)操作。
O(logn):当集合的大小增加时,执行操作所花费的时间对数增加。这是对数时间复杂度表示法。潜在优化的搜索算法为O(logn)。
O(n):执行操作所需的时间与集合中的项目数成线性正比。这是线性时间复杂度符号。就性能而言,这介于两者之间或中等。作为一个实例,如果我们想对一个集合中的所有项目求和,那么我们将不得不遍历该集合。因此,集合的迭代是O(n)操作。
(nlogn):执行某项操作的性能是集合中项目数量的拟线性函数。这称为准线性时间复杂度表示法。优化排序算法的时间复杂度通常为n(logn)。
O(n平方):执行操作所需的时间与集合中项目的平方成正比。这称为二次时间复杂度表示法。
(n!):当在操作中计算集合的每个单个排列时,因此执行操作所需的时间取决于集合中项目的大小。这称为阶乘时间复杂度表示法。非常慢。
该图像概述了Big-O符号。
O(1)很快。O(n平方)很慢。O(n!)非常慢。
大O符号是相对的。大O表示法与机器无关,忽略常量,并且被包括数学家,技术人员,数据科学家等在内的广泛读者所理解。
最佳,平均,最差情况
当我们计算操作的时间复杂度时,我们可以根据最佳,平均或最坏情况产生复杂度。
最佳情况方案:顾名思义,这是当数据结构和集合中的项目以及参数处于最佳状态时的方案。例如,假设我们要在集合中找到一个项目。如果该项目恰好是集合的第一项,那么这是该操作的最佳情况。
平均情况是根据输入值的分布定义复杂度。
最坏的情况是可能需要一种操作,该操作需要在大型集合(例如列表)中找到位于最后一个项目的项目,并且算法会从第一个项目开始对集合进行迭代。
以上内容为大家介绍了Python数据结构的时间复杂性,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注我们http://www.mobiletrain.org/
最新内容
相关内容
Python网络编程调用接收数据的三种
Python网络编程调用接收数据的三种方法,数据,代码,基础,通用,通讯,服务,网络,培训,方法,报文,最近在使用python进行网络编程开发一个通用的tc为什么开发人员喜欢在机器学习和人
为什么开发人员喜欢在机器学习和人工智能项目中使用Python?,代码,项目,数据,人工智能,平台,异常,增长,灵活,时间,工具,1.Python是灵活的Pytho数据科学领域Python比R语言更好
数据科学领域Python比R语言更好,数据,公司,工具,时间,项目,工作,庞大,受益,系统,代码,经常有学员问我们,在数据科学领域里,到底是该选Python呢,Python语言自带的数据结构有哪些
Python语言自带的数据结构有哪些,异常,数字,数据,元素,序列,培训,位置,名称,分析,括号,Python作为一种脚本语言,其要求强制缩进,使其易读、美观提升Python数据分析能力的方法
提升Python数据分析能力的方法,分析,数据,工具,代码,时间,环境,报告,信息,培训,标准,1.Pandas分析包这个工具的好处是显而易见的。下面的动画用于业余项目的优秀 Python 库
用于业余项目的优秀 Python 库,数据,工具,项目,信息,培训,系统,地图,下来,工作,管理,1.在数据库中即时保存数据:Dataset当我们想要在不知道最数据科学中必须了解的Python核心库
数据科学中必须了解的Python核心库,数据,生产,代码,标准,分析,培训,图片,工具,统一,涉足,python有三个核心数据科学库,在此基础上还创建了许多Python集合和时间复杂度
Python集合和时间复杂度,项目,时间,数据,数字,照片,情况,通用,培训,平均,表示,在本文的这一部分中,我将记录CPython中的常见集合,然后概述它们使用Python处理JSON格式的数据
使用Python处理JSON格式的数据,数据,代码,名称,信息,培训,对比,灵活,字典,文件,格式,如果你不希望从头开始创造一种数据格式来存放数据,JSON是Python变量数据类型的转换
Python变量数据类型的转换,代码,数据,培训,信息,字符串,类型,变量,整数,浮点,函数,虽然Python是弱类型编程语言,不需要像Java或C语言那样还要Python中常用的 json 操作有哪些?
Python中常用的 json 操作有哪些?,数据,培训,标准,对象,函数,参数,操作,字符串,下面,文件,刚开始接触json的操作,我主要有下面几个疑问:json操Python文件操作步骤示例
Python文件操作步骤示例,异常,代码,信息,文件,设计,简介,通用,意外,中级,培训,我们来读取这样一个文本文件:song.txt,该文件的字符编码为utf-8