现在应该先学哈希表再看算法,还是先看算法,leetcode第一题竟然有哈希,懵了。还有算法应该以什么顺序去学习😭
1条回答 默认 最新
一轮明月照丘壑 2024-09-23 21:11关注以下回复参考:皆我百晓生、券券喵儿等免费微信小程序作答:
在C++算法学习中,建议先理解基本的算法和数据结构,然后再学习哈希表等高级数据结构。关于算法的学习顺序,以下是一些建议:
一、基础算法和数据结构:
- 数据结构:理解数组、链表、栈、队列、树(二叉树等)、图等基础数据结构的概念和操作。
- 基本算法:学习排序(如冒泡排序、插入排序、快速排序等)、查找(如二分查找)等常用算法。
二、进阶数据结构:
- 哈希表:当基础算法和数据结构掌握得差不多时,可以开始学习哈希表。哈希表是一种通过计算数据的哈希值来快速存取数据的数据结构。了解哈希表的原理、实现和使用场景。
三、算法的学习顺序:
- 动态规划:动态规划是许多算法问题的核心思想,解决很多问题时非常有效。建议先学习动态规划,再学习其他算法。
- 图论算法:如最短路径、最小生成树等,这些是计算机科学中的核心问题。
- 字符串算法:字符串问题在很多编程比赛中都有涉及,例如KMP字符串匹配算法等。
- 高级数据结构题:如二叉搜索树、并查集等,这些通常涉及到哈希表的应用。
四、结合实际问题学习:
通过实际编程问题,特别是像LeetCode这样的在线编程平台上的题目来实践和学习算法。这样做不仅可以加深对算法的理解,还可以提高编程能力。
关于LeetCode第一题涉及到哈希的情况,其实不用太担心。只要掌握了基础的算法和数据结构,再遇到具体问题时,可以根据问题的特点选择合适的算法和数据结构来解决。遇到不懂的问题,可以多查阅资料,看别人的解答,逐渐积累经验。
总之,学习C++的算法和数据结构需要循序渐进,先从基础开始,逐渐深入。同时,结合实际问题来学习和实践,效果会更好。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报