代码随想录-第二章:时间复杂度

2.1什么是时间复杂度

开发者通过时间复杂度来评估程序运行的时间,通常以算法的操作单元数量来代表程序消耗的时间。O(),这个O表示上界,即最坏的情况下的时间复杂度。计算时间复杂度的时候,只保留表达式的最高项,并去掉常数,认为其他对比最高项都影响不大。O(logn),认为忽略底数,因为可以换底,换底的表达式就是个常数。

找n个字符串中相同的两个字符串

暴力枚举:

n个字符串,每个字符串长度为m

两层for循环:是无序的两两组合----Cn2=n+(n-1)+(n-2)+...+1

比较字符串,相当于一个for循环,判断m次字符是不是相等(判断行为被CPU认为是最简单的操作,复杂度是O(1))

快速排序再遍历比较:

快速排序:每次都选一个值,然后跟其他做比较大小,小的放左边大的放右边

例子第一层比较7次第二层比较2+3次,但时间复杂度看上限,所以就按8来,认为每层都比较n次

对半切然后相加就是log2,n(也是因为这样切次数是最多的),所以最终快速排序就是nlogn

相关推荐
变量未定义~1 分钟前
摆放小球 、dp求解组合数、求解组合数2
数据结构·算法
一头老黄牛@14 分钟前
飞书 × OpenClaw 接入指南:不用服务器,用长连接把机器人跑起来
数据结构·人工智能·程序人生·算法·决策树·自动化·推荐算法
Zhan8611242 小时前
数据接口的序列号机制与丢包检测:西班牙行情数据IBEX指数实时行情接入笔记
大数据·数据结构·笔记·区块链
退休倒计时12 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
2601_9618752412 小时前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
dtq042415 小时前
C语言刷题数组5,6(求平均值,求最大值)
c语言·数据结构·算法
洛水水16 小时前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
Coder-magician16 小时前
《代码随想录》刷题打卡day15:二叉树part05
数据结构·c++·算法
Darling噜啦啦16 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构
Irissgwe17 小时前
算法的时间复杂度和空间复杂度
数据结构·c++·算法·c·时间复杂度·空间复杂度