栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

黑马 Python 数据结构与算法第一章

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

黑马 Python 数据结构与算法第一章

背景知识

 

1.数组是一种线性表结构,其用一块连续的内存空间,来存储一组具有相同类型的数据;
2.时间复杂度,也叫做渐进时间复杂度,通常用大O公式书写,表示代码的执行时间随数据规模增长的变化趋势,而非真正的执行时间。因此大O关注的是变化趋势。

常见的时间复杂度高低排序:
O(1) list内置操作的时间复杂度:

列表相加

append  n

extend

列表生成式

range生成

# ('concat ', 1.7890608310699463, 'seconds')
# ('append ', 0.13796091079711914, 'seconds')
# ('comprehension ', 0.05671119689941406, 'seconds')
# ('list range ', 0.014147043228149414, 'seconds')

都是考虑最坏情况:例如需要指定位置pop可能为Pop(0),也有可能是pop(n-1),所以为O(n)

O(k): k = y - x 其实是常数

删除:需要把后面的元素往前移

列表设置切片:n+k ,切片+移动元素

需要记住的:

O(1):索引,队尾添加(index,append,尾部pop)

O(n):任意位置弹出、插入,查找(任意位置pop,insert)

        通过分析可以发现,列表不太适合做元素的遍历、删除、插入(insert)等操作,对应的时间复杂度为O(n);访问某个索引的元素、尾部添加元素或删除元素这些操作比较适合做,对应的时间复杂度为O(1)。

数据结构

特定的数据结构和始于用他的方法叫做抽象数据类型;

规定数据怎样保存 —— 这些数据支持哪些操作,先把接口定义出来(先不管操作具体怎么实现)

tips:

timeit模块:

timeit模块可以用来测试一小段Python代码的执行速度

from timeit import Timer

t1 = Timer("test1()", "from __main__ import test1")

## stmt参数:'test()'是要测试的代码语句(statment)

## setup:"from __main__ import test1" 是运行代码时需要的设置;

## timer参数是一个定时器函数,与平台有关。

print("concat ",t1.timeit(number=1000), "seconds")

​​​​​​​

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/657841.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号