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

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

相关推荐
ysa0510302 小时前
【并查集】判环,深搜
数据结构·c++·算法·深度优先
.Hypocritical.4 小时前
数据结构笔记——链表成环/反转 + 有序二叉树(BST)构建、遍历、删除
java·数据结构
CSharp精选营5 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假8 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠9 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦16 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠17 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾17 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82117 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q17 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集