什么是数据结构?什么是算法?
- 广义概念
数据结构就是指一组数据的存储结构。算法就是操作数据的一组方法
- 狭义概念
指某些著名的数据结构和算法,比如队列、栈、堆、二分查找、动态规划等。这些经典数据结构和算法,都是前人从很多实际操作场景中抽象出来的,经过非常多的求证和检验,可以高效的帮助我们解决很多实际的开发问题。
学习重点
- 复杂度分析
复杂度分析占据了数据结构和算法的半壁江山,是数据结构和算法的精髓。
数据结构和算法解决的是如何更省、更快的存储和处理数据的问题,因此,我们就需要一个考量效率和资源消耗的方法,这就是复杂度分析方法。
- 正文
图中包含了所有数据结构和算法书籍中都会讲到的知识点。
作为初学者,或者非算法工程师,并不需要掌握图中的所有知识点。
以下20个是最常用、最基础的数据结构和算法:
- 10个数据结构:数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie树
- 10个算法:递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法、动态规划、字符串匹配算法