当前位置: 首页 > news >正文

面试算法-常用数据结构

文章目录

  • 数据结构
    • 数组
    • 链表
  • 队列
  • 双端队列

1)算法和数据结构

image.png
2)判断候选人的标准

image.png

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

数据结构

数组

image.png

链表

优点:
1)O(1)时间删除或者添加
灵活分配内存空间

缺点:
2)查询需要O(n) 时间

解题技巧:
1)利用快慢指针
2)构建一个虚假的链表头

如何训练技巧:
1)在纸上或者白班上画出节点之间的相互关系

2)画出修改的方法

特点:后进先出(LIFO)

算法基本思想:

1)可以用一个单链表来实现
2)只关心上一次的操作
3)处理完上一次操作后,能在O(1)时间内查找到更前一次的操作

队列

特点:先进先出(FIFO)

常用场景:

广度优先搜索算法

双端队列

基本实现:
1)可以利用一个双链表

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

常用场景:
实现一个长度动态变化的窗口或者连续区间

image.png

树的共性:

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

面试中常考的树的形状有

1)普通二叉树
2)平衡二叉树
3)完全二叉树
4)二叉搜索树 (重点)
5)四叉树
6)多茶树

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

遍历:(递归和非递归)+ 分析时间复杂度
前序遍历
中序遍历
后续遍历

image.png

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

http://www.lryc.cn/news/157224.html

相关文章:

  • 【动态规划刷题 10】等差数列划分 最长湍流子数组
  • redis 配置与优化
  • 数据结构例题代码及其讲解-递归与树
  • Jenkins | 流水线构建使用expect免密交互时卡住,直接退出
  • git修改默认分支
  • Android Studio开发入门教程:如何更改APP的图标?
  • MATLAB/Python的编程教程: 匹配滤波器的实现
  • java八股文面试[数据库]——JOIN优化
  • Java语法中一些需要注意的点(仅用于个人学习)
  • golang 线程 定时器 --chatGPT
  • java 编程 7个简单的调优技巧
  • 03-Dockerfile
  • 【AI】机器学习——朴素贝叶斯
  • 数学建模:模糊综合评价分析
  • 智能小车—PWM方式实现小车调速和转向
  • Getx其他高级API
  • npm/yarn link 测试包时报错 Warning: Invalid hook call. Hooks can only be called ...
  • 「网页开发|前端开发|Vue」06 公共组件与嵌套路由:让每一个页面都平等地拥有导航栏
  • leetcode687. 最长同值路径(java)
  • MySQL的常用术语
  • 机器学习的特征工程
  • python3 修改nacos的yaml配置
  • YOLOv8 : 数据组织
  • golang如何生成zip压缩文件
  • AntDesign技术指南:构建优雅的前端界面
  • 机器人任务挖掘与智能超级自动化技术解析
  • C#通过ModbusTcp协议读写西门子PLC中的浮点数
  • 19-springcloud(中)
  • Leetcode1090. 受标签影响的最大值
  • 第七章:敏捷开发工具方法-part2-CI/CD工具介绍