数据结构与算法之美---02 如何抓住重点,系统高效地学习?
什么是数据结构?什么是算法? 从广义上讲,数据结构就是指一组数据的存储结构。算法就是操作数据的一组方法。 从狭义上讲,是指某些著名的数据结构和算法,比如队列、栈、堆、二分查找、动态规划等。 个人理解:(不知道正确与否) 数据结构是两部分,一个是数据,一个是结构,比如文档讲的图书馆藏书编号,数据是书籍,编号的规律就是结构,合起来就是数据结构。? 数据结构和算法什么关系? 数据结构和算法是相辅相成的。 数据结构是为算法服务的,算法要作用在特定的数据结构之上。 数据结构是静态的,它只是组织数据的一种方式。如果不在它的基础上操作、构建算法,孤立存在的数据结构就是没用的。 个人理解:(不知道正确与否) 不同的数据结构,使用的算法不同。同一数据的不同结构,可能使用的算法也不一样。 重点: 数据结构与算法中最重要的概念—— 复杂度分析 。 数据结构和算法解决的是如何更省、更快地存储和处理数据,考量效率和资源消耗的方法,就是复杂度分析法。 10 个数据结构:数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie 树; 10 个算法:递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法、动态规划、字符串匹配算法。 掌握数据结构与算法要点:“来历”“自身的特点”“适合解决的问题”以及“实际的应用场景” 学习技巧: 1. 边学边练,适度刷题 建议你每周花 1~2 个小时的时间