面试算法-常用数据结构

文章目录

1)算法和数据结构

2)判断候选人的标准

  • 算法能力能够准确辨别一个程序员的功底是否扎实

数据结构

数组

链表

优点:

1)O(1)时间删除或者添加

灵活分配内存空间

缺点:

2)查询需要O(n) 时间

解题技巧:

1)利用快慢指针

2)构建一个虚假的链表头

如何训练技巧:

1)在纸上或者白班上画出节点之间的相互关系

2)画出修改的方法

特点:后进先出(LIFO)

算法基本思想:

1)可以用一个单链表来实现

2)只关心上一次的操作

3)处理完上一次操作后,能在O(1)时间内查找到更前一次的操作

队列

特点:先进先出(FIFO)

常用场景:

广度优先搜索算法

双端队列

基本实现:

1)可以利用一个双链表

2)队列的头部和尾部都能在O(1)的时间内进行数据的查看,添加和删除

常用场景:

实现一个长度动态变化的窗口或者连续区间

树的共性:

1)结构直观

2)通过树问题来考察 递归算法掌握的熟练程度

面试中常考的树的形状有

1)普通二叉树

2)平衡二叉树

3)完全二叉树

4)二叉搜索树 (重点)

5)四叉树

6)多茶树

特殊的树:红黑树,自平衡二叉树

遍历:(递归和非递归)+ 分析时间复杂度

前序遍历

中序遍历

后续遍历

二叉搜索树的中序遍历:是从小到大排序好的

相关推荐
CoderCodingNo1 分钟前
【GESP】C++五级练习题 luogu-B3628 机器猫斗恶龙
开发语言·c++·算法
橘颂TA9 分钟前
【剑斩OFFER】算法的暴力美学——力扣 1020 题:飞地的数量
数据结构·c++·算法·leetcode·职场和发展·结构与算法
hetao173383715 分钟前
2026-01-27~28 hetao1733837 的刷题记录
c++·笔记·算法
2301_8223663517 分钟前
C++中的智能指针详解
开发语言·c++·算法
探序基因18 分钟前
查看bam文件指定位点的基因测序情况计算基因型
数据结构·学习方法
u01092727143 分钟前
C++中的模板方法模式
开发语言·c++·算法
重生之我是Java开发战士1 小时前
【优选算法】滑动窗口:长度最小的子数组,无重复字符的最长子串,最大连续1的个数,将x减到0的最小操作数,水果成篮,异位词,串联所有单词的子串,最小覆盖子串
算法
naruto_lnq1 小时前
C++与自动驾驶系统
开发语言·c++·算法
啊阿狸不会拉杆1 小时前
《数字信号处理》第6章:数字滤波器的基本概念及几种特殊滤波器
算法·matlab·信号处理·数字信号处理·dsp
奶茶树1 小时前
【数据结构进阶】AVL树(详解)
数据结构·c++