https://blog.youkuaiyun.com/qiaobinXU/article/details/83015631
开始学习数据结构和算法啦。
希望学完后能掌握这块的知识。
什么是数据结构?什么是算法?
简单理解,可以从广义和狭义两个层面来说。
广义上说,数据结构就是指一组数据的存储结构,算法就是操作数据的一组方法。
狭义上说,是指某些著名的数据结构和算法。比如队列、栈、堆、二分查找、动态规划等。
数据结构和算法的关系?
数据结构和算法是相辅相成的。数据结构是为算法服务的,算法要作用在特定的数据结构上。
比如,因为数组具有随机访问的特点,常用的二分查找算法需要用数组来存储数据。但如果我们选择链表这种数据结构,二分查找算法就无法工作了,因为链表并不支持随机访问。
数据结构是静态的,它只是组织数据的一种方式。如果不在它的基础上进行操作、构建算法,孤立存在的数据结构是没有用的。
学习的重点?
1、复杂度分析
数据结构和算法解决的是更快、更省的存储和处理数据的问题。所以需要一个方法来考量效率和资源消耗的情况,这就是复杂度分析。
2、数据结构和算法的内容
在工作中,攻克常用的20个知识点就足够了。
10个数据结构:数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie树
10个算法:递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法、动态规划、字符串匹配算法。
去LeetCode刷刷题