字符串匹配算法为何如此重要从KMP到Z函数的线性时间突围

假设你需要在一段百万字的文本中搜索一个关键词。最直观的方法是:将关键词与文本的每个位置逐一比较——时间复杂度 $O(nm)$,其中n是文本长度,m是关键词长度。当文本达到百万级别时,这个算法可能需要数秒甚至更长。 ...

9 min · 4081 words

数论算法为何成为LeetCode的隐藏Boss从素数筛到快速幂的完整通关指南

假设你需要统计小于1000万的整数中有多少个素数。最直观的想法是:对每个数逐一判断是否为素数——时间复杂度 $O(n\sqrt{n})$,当数据量达到千万级别时,程序可能需要运行数秒甚至数分钟。但如果换一个思路:用一个布尔数组标记所有合数,剩下的就是素数——时间复杂度骤降至 $O(n \log \log n)$,千万级数据量下只需几十毫秒。 ...

9 min · 4238 words

位运算为何能让一行代码抵十行循环从底层原理到LeetCode完整通关指南

假设你需要统计一个整数二进制表示中1的个数。最直观的想法是:转成二进制字符串,遍历统计每个字符——代码大概十行左右。但如果告诉你,用一行循环就能搞定,甚至不需要字符串转换呢? ...

11 min · 5181 words

排序算法为何如此重要从快速排序到TimSort的八十年演进与LeetCode完整通关指南

1961年,英国计算机科学家Tony Hoare在为机器翻译项目开发字典排序功能时,发明了一种在当时看来极其反直觉的算法:随机选择一个元素作为基准,将数组分成两部分递归排序。这个算法就是后来统治计算机排序领域半个多世纪的快速排序。 ...

12 min · 5526 words

最小生成树为何能用两种截然不同的方式构建从Prim到Kruskal的完整LeetCode通关指南

假设你需要为$n$个城市铺设光缆,每两个城市之间的铺设成本各不相同。如何用最低的总成本让所有城市互联互通?这看似是一个复杂的优化问题,实际上可以抽象为图论中的经典问题——最小生成树(Minimum Spanning Tree,简称MST)。 ...

12 min · 5952 words

LRU缓存淘汰策略如何用O(1)时间完成get与put操作从双向链表到HashMap的精妙结合

1966年,计算机科学家们在设计操作系统时面临一个核心问题:当内存空间有限而需要存储的数据量无限增长时,应该删除哪些数据?这个看似简单的问题催生了缓存淘汰策略的研究。在众多策略中,LRU(Least Recently Used,最近最少使用)因其简单直观的思想和优秀的实际表现,成为应用最广泛的缓存淘汰算法之一。 ...

10 min · 4940 words

最短路径算法为何如此重要从Dijkstra到Floyd的四种实现方式与LeetCode完整通关指南

1956年的某个早晨,荷兰计算机科学家艾兹赫尔·戴克斯特拉(Edsger W. Dijkstra)在阿姆斯特丹的一家咖啡馆里,只用20分钟就在脑海中设计出了最短路径算法。当时他正在和未婚妻逛街,甚至没有用纸笔——这个"20分钟的发明"后来成为计算机科学史上最著名的算法之一,被广泛应用于GPS导航、网络路由、社交网络分析等无数领域。 ...

14 min · 6744 words