什么是数据结构?什么是算法?
数据结构就是数据的存储结构;算法就是操作数据的方法。
举个例子:
图书馆藏书为了方便查找,图书管理员一般将各种书籍分类别的放在一起。这种分类存放就是书籍这种数据 的结构。然后在查找的时候,我们当然可以一本一本挨着的查找,或者是首先查找对应的类别 ,然后再查找对应的编号。这种查找的方式都叫算法。
具体数据结构:数组、链表、树、图等等
具体的算法:二分查找、动态规划、dfs、bfs等等
学习的重点在什么地方?
首先要掌握时间复杂度分析。数据结构和算法解决的 都是如何更省、更快地存储和处理数据的问题,因此我们要考虑效率和资源消耗。下图很多高级的数据结构与算法,比如二分图、最大流等,这些在我们平常的开发中很少会用到。
20 个最常用的、最基础数据结构与算法
10 个数据结构:数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie 树;
10 个算法:递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法、动态规划、字符串匹配算法