数据结构 - 从零开始(2)

45 阅读1分钟

什么是数据结构?什么是算法?

从广义上讲,数据结构是一组数据的存储结构,算法是操作数据的一组方法。

从狭义上讲,数据结构和算法是相辅相成的,数据结构是为算法服务的,算法作用于特定的数据结构之上。

举例:常用的二分查找算法,一般使用数组作为存储数据的数据结构,因为数组具有随机访问的特点,而链表不具备该特点,所以不能用链表作为数据结构存储数据。

学习的重点在什么地方?

想要学习数据结构与算法,首先要掌握一个最重要的概念:复杂度分析。它是数据结构和算法学习中的精髓。归根结底数据结构和算法解决的是如何更快、更省地解决问题,所以我们需要一个考量效率和资源消耗的的方法,也就是复杂度分析方法。

除此之外我们还要了解在数据结构与算法中,需要学习的知识点有哪些,如下图所示

这里面有十个数据结构和十个算法是我们最常用、最基础的,也是我们学习的重中之重。

10 个数据结构:数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie 树;10 个算法:递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法、动态规划、字符串匹配算法。