【数据结构与算法01】 算法的复杂度

简介: 【数据结构与算法01】 算法的复杂度

时间复杂度的概念


067645e4dc61257ef3680136adca6a1a.png


例1:假设n = 3000 n=3000n=3000


a66b05e4ffd2fd0fc9c67f84e3aa8999.png


i=2998,print("I love You %d\n",i)
i=2999,print("I love You %d\n",i)
i=3000,print("I love You %d\n",i)


当i=3001,经过判断,i<=n不成立


所以,while循环执行3001次(步骤2),while循环里面的++、print执行了3000次,其它1、5执行了1次


T(3000)=1+3001+2x3000+1,所以T(n)=3n+3,n=3000


🔥结论:计算时间复杂度只需要考虑阶数高的部分


faae873ad2e9583ff5c651d93e78a96b.png


  • 加法规则


多项相加,只保留最高阶的项,并且系数变为1


4fcf1ad8af64fd366e32701707e40c82.png


  • 乘法规则


时间复杂度:常[1]、对[logn]、幂[n^2]、 指[2^n]、阶[n!]


f8f687d534e8d0b8edaf7c708f5fbb85.png


🌈时间复杂度的大小关系:


image.png

cb1ce3627dd9aceba5971380d1b66146.png


例题


3fbcc44351eed17070f821894ace66d3.png


dbb365e62d8567b4d5a49cf5b6a1b739.png


❗易错提醒


1.程序不一定满足有穷性,如死循环、操作系统等;而算法必须有穷


2.算法满足5个基本特性(这是算法的要求而不是定义)


3.算法的时间复杂度为O ( n 2 ) ,在这里问题规模是n,时间复杂度是 O ( n 2 )


4.在相同的规模下,O ( n ) < O ( n 2 )


✅正确!时间复杂度制定了n无穷大,故不能带入特殊值n0考虑


空间复杂度


f620f6449d80769135aaa437131a8c1e.png



🍔算法原地工作:算法所需的内存空间为常量


1个int变量占4Byte,32bit


例题


c8f89faa2d79475d01663bf9bd5d37ef.jpg


所以,空间复杂度等于递归调用的深度


1542c73dd87383a864df1eac295ebfe2.jpg

相关文章
|
5天前
|
存储 监控 NoSQL
Redis处理大量数据主要依赖于其内存存储结构、高效的数据结构和算法,以及一系列的优化策略
【5月更文挑战第15天】Redis处理大量数据依赖内存存储、高效数据结构和优化策略。选择合适的数据结构、利用批量操作减少网络开销、控制批量大小、使用Redis Cluster进行分布式存储、优化内存使用及监控调优是关键。通过这些方法,Redis能有效处理大量数据并保持高性能。
25 0
|
4天前
|
缓存 算法 Java
数据结构~缓存淘汰算法--LRU算法(Java的俩种实现方式,万字解析
数据结构~缓存淘汰算法--LRU算法(Java的俩种实现方式,万字解析
|
5天前
|
机器学习/深度学习 算法 数据可视化
Python 数据结构和算法实用指南(四)(4)
Python 数据结构和算法实用指南(四)
10 1
|
5天前
|
机器学习/深度学习 存储 算法
Python 数据结构和算法实用指南(四)(3)
Python 数据结构和算法实用指南(四)
15 1
|
5天前
|
存储 算法 搜索推荐
Python 数据结构和算法实用指南(四)(2)
Python 数据结构和算法实用指南(四)
10 0
|
5天前
|
存储 算法 Serverless
Python 数据结构和算法实用指南(四)(1)
Python 数据结构和算法实用指南(四)
14 0
|
5天前
|
存储 算法 搜索推荐
Python 数据结构和算法实用指南(三)(4)
Python 数据结构和算法实用指南(三)
10 1
|
5天前
|
存储 搜索推荐 算法
Python 数据结构和算法实用指南(三)(3)
Python 数据结构和算法实用指南(三)
10 1
|
5天前
|
存储 算法 前端开发
Python 数据结构和算法实用指南(三)(2)
Python 数据结构和算法实用指南(三)
10 1
|
5天前
|
存储 算法 编译器
Python 数据结构和算法实用指南(三)(1)
Python 数据结构和算法实用指南(三)
13 1