2024数据结构最新面试题(大厂必备)(1),vue面试官系列

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

4.什么是存储结构?

1.顺序存储

2.链式存储

3.索引存储

4.散列存储

5.数据的操作

1.逻辑机构,存储结构,和运算 是数据结构讨论中不可分割的3个方面

6.算法概述

1.算法是对特定问题求解步骤的一种描述,是指令的有限序列。其中每条指令表示一个或多个操作。

7.算法的五种性质

1.有穷性

2.确定性

3.有效性

4.输入

5.输出

8.算法设计的目标

1.正确性

2.可读性

3.健壮性

4.高效率(时间与空间)

9.数据操作

1.初始化:创建、销毁:

2.数据操作:插入/添加、删除、修改

3.数据使用:查找、遍历

10.算法的描述方式:

1.自然语言

2.程序设计语言

3.伪代码

4.流程图

11.多项式时间算法的时间复杂度有多种形式,其中最常见的形式如下

1.常量阶:O(1)

2.线性阶:O(n)

3.平方阶:O(n2)

4.立方阶

5.对数阶

6.线性对数阶

12.按照数据元素之间逻辑关系的特性来分,可将数据结构归纳为以下4类:

1.集合

集合中数据元素之间除了“同属于一个集合”的特性外,数据元素之间无其他关系,它们之间的关系称为是松散性的

2.线性结构

线性结构中数据元素之间存在“一对一”的关系

3.树形结构

树形结构中数据元素之间存在“一对多”的关系

4.图形结构

图形结构中数据元素之间存在“多对多”的关系

13.算法的时间复杂度分析

算法时间复杂度的高低直接反应算法执行时间的长短,而算法的执行时间需要通过依据该算法编写的程序在计算机上执行所消耗的时间来度量

14.影响一个程序的执行时间的主要因素有如下几个方面

1.算法本身所用的策略

2.问题规模即处理问题时所处理的数据元素的个数

3.程序设计所采用的语言工具

4.编译程序所产生的机器代码质量

5.计算机执行指令的硬件速度

6.程序运行的软件环境

15.线性表:是一种最常用、最简单,也是最基本的数据结构

16.线性表由n个数据元素所构成的有限序列,且数据类型相同

17.线性表可以用`顺序存储`和`链式存储`两种存储结构来表示

使用`顺序存储`的线性表称为顺序表。

使用`链式存储`的线性表称为链表。

18.链表的分类:单链表、双向链表、循环链表

19.顺序表就是顺序存储的线性表

20.顺序存储是用一组地址连续的存储单元依次存放线性表中各个数据元素的存储结构

1.在逻辑上,数据ABCD是连续

2.在物理上,地址也是连续的

21.线性表地址公式:Loc(Ai) = Loc(A0) + i * c => (第i的地址 = 第一个地址 + 第几个 * 存储单位)

22.顺序表特点

1. 在线性表中逻辑上相邻的数据元素,在物理存储位置上也是相邻的。

2. 存储密度高。但需要预先分配“足够”的存储空间。

存储密度 = 数据元素存储空间 / 数据元素实际占用空间

在顺序表中,存储密度为1。

3. 便于随机存储。(数组中可以通过下标进行存储)

4. 不便于插入和删除操作。两种操作都会引起大量的数据移动。

23.顺序表的插入操作:

将第i个数据元素及其之后的所有的数据元素,后移一个存储位置,再将新元素插入到i处

/**

* @Param i 第i个位置

* @Param x 需要插入的数据

*/

public void insert(int i, Object x) {

//0.1 满校验:存放实际长度 和 数组长度 一样

if(curLen == listEle.length) {

throw new Exception(“已满”);

}

//0.2 非法校验,在已有的数据中间插入 [0, curLen],必须连续,中间不能空元素

if(i < 0 || i > curLen) {

throw new Exception(“位置非法”);

}

//1 将i及其之后后移

for(int j = curLen ; j > i; j --) {

listEle[j] = listEle[j-1];

}

//2 插入i处

listEle[i] = x;

//3 记录长度

curLen ++;

最后

我还通过一些渠道整理了一些大厂真实面试主要有:蚂蚁金服、拼多多、阿里云、百度、唯品会、携程、丰巢科技、乐信、软通动力、OPPO、银盛支付、中国平安等初,中级,高级Java面试题集合,附带超详细答案,希望能帮助到大家。

新鲜出炉的蚂蚁金服面经,熬夜整理出来的答案,已有千人收藏

还有专门针对JVM、SPringBoot、SpringCloud、数据库、Linux、缓存、消息中间件、源码等相关面试题。

新鲜出炉的蚂蚁金服面经,熬夜整理出来的答案,已有千人收藏

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-zuF3cJhf-1713211406823)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 15
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值