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

背景知识

 

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

常见的时间复杂度高低排序:
O(1)<O(logn)<O(n)<O(nlogn)<O(n²)<O(n²logn)<O(n³)<O(2ⁿ)<O(n!)<O(nⁿ)

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")

​​​​​​​

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
├─01基础 │ │ 第1节 linux操作系统基础 │ │ 第2节 python语法基础 │ │ 第3节 项目-飞机大战 │ │ 补充资料 │ │ │ └─第1节 linux操作系统基础 │ └─01.Linux以及命令 │ └─视频 │ 04-unix、minix、Linux操作系统的发展1.flv │ ├─02Python核心编程 │ 第1节 python高级编程 │ 第2节 linux系统编程 │ 第3节 网络编程 │ 第4节 web服务器案例 │ 第5节 正则表达式 │ ├─03数据结构与算法 │ 第1节 数据结构和算法基础 │ 第2节 顺序表 │ 第3节 栈与队列 │ 第4节 链表 │ 第5节 排序与搜索 │ 第6节 树与树算法 │ 资料 │ ├─04数据库 │ 第1节 MySQL │ 第2节 MongoDB │ 第3节 Redis │ ├─05前端 │ 第1节 HTML │ 第2节 CSS │ 第3节 PhotoShop │ 第4节 HTML5+CSS3 │ 第5节 移动端页面开发 │ 第6节 JavaScript │ 第7节 JQuery │ 第8节 移动端JS库 │ 第9节 Bootstrap │ 资料 │ ├─06django │ 第1节 Django │ 第2节 天天生鲜项目思路 │ 第3节 Git │ 资料 │ ├─07爬虫 │ 第1节 Python爬虫基础类库 │ 第2节 scrapy框架 │ 第3节 scrapy-redis分布式策略 │ 资料 │ ├─08 tornado │ 第1节 Tornado │ 第2节 爱家租房项目 │ 第3节 微信公众号 │ 资料 │ ├─09shell和自动化运维 │ 第1节 运维和shell │ 第2节 shell常用工具 │ 第3节 nginx │ 第4节 自动化部署 │ 资料 │ ├─课件和资料 5

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值