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

Java数据结构面试题以及答案

本专栏记录Java后端开发相关的面试题,欢迎大家阅读专栏的其他文章。

目录

1.B树和B+树的区别?B树和B+树的优点分别是?

2.排序算法的种类和复杂度

3.HashMap和Hashtable的原理、区别、应用场景

4.ConcurrentHashMap的原理、应用场景

5.ArrayList和LinkedList的区别?原理?应用场景?

6.String、StringBuilder和StringBuffer的区别,应用场景

7.ArrayList和Vector的区别

8.Collection下有哪些子类

9.Comparable和Comparator的区别


 

1.B树和B+树的区别?B树和B+树的优点分别是?

B树和B+树详细解析_星空是梦想的博客-CSDN博客

1.1 B树和B+树的区别

B树特征:

  • 关键字集合分布在整颗树中
  • 每个结点都存放有若干个 key 和 value
  • 任何一个关键字出现且只出现在一个结点中
  • 搜索有可能在非叶子结点结束
  • 其搜索性能等价于在关键字全集内做一次二分查找

B+树特征:

  • 非叶子结点不保存数据,只保存 key,所有数据都保存在叶子节点
  • 所有的叶子结点中包含了全部关键字的信息,及指向含这些关键字记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接
  • 所有的非叶子结点可以看成是索引部分,结点中仅含其子树中的最大(或最小)关键字
  • 通常在b+树上有两个头指针,一个指向根结点,一个指向关键字最小的叶子结点
  • 同一个数字会在不同节点中重复出现,根节点的最大元素就是b+树的最大元素

B树和B+树区别:

  • B+树的中间节点不保存数据,所以磁盘页能容纳更多节点元素,更“矮胖”
  • b+树查询必须查找到叶子节点,b树只要匹配到即可不用管元素位置,因此b+树查找更稳定(并不慢)
  • 对于范围查找来说,b+树只需遍历叶子节点链表即可,b树却需要重复地中序遍历

1.2 B树的优点

相比于普通的二叉树来说,B树是平衡二叉树,它增加和删除节点对树的整体结构来说,改动非常小,适合用来存储大数据

1.3 B+树的优点

  • b+树的中间节点不保存数据,所以磁盘页能容纳更多节点元素,更“矮胖”
  • b+树查询必须查找到叶子节点,b树只要匹配到即可不用管元素位置,因此b+树查找更稳定(并不慢)
  • 对于范围查找来说,b+树只需遍历叶子节点链表即可,b树却需要重复地中序遍历

2.排序算法的种类和复杂度

2.1 什么是算法的空间复杂度

算法的空间复杂度是指:算法在运行过程中,除了存储算法基本数据的空间外,需要耗费的额外空间。

2.2 排序算法的时间和空间复杂度

排序算法的时间和空间复杂度
算法名称时间复杂度空间复杂度
冒泡排序O(n^2)O(1)
直接插入排序O(n^2)O(1)
直接选择排序O(n^2)O(1)
快速排序O(n*logn)O(n*logn)
希尔排序O(n*logn)O(1)
堆排序O(n*logn)O(1)

计数排序

介绍

O(d(n+k))O(n+k)
归并排序O(n*logn)

O(n)

 

 

        

 

 

 

 

 

 

 

 

3.HashMap和Hashtable的原理、区别、应用场景

3.1 原理

  1. HashMap 和 Hashtable 的底层结构都是 数组+链表结构实现的。数组用于存储链表头节点,新增元素都会添加到对应位置的链表末尾,链表节点数量超过 8 时,链表会转化为红黑树。
  2. 它们的链表节点中有一个 hash 变量,用于存储该结点的 hash 值,通过 hash值 可以快速定位元素位置。

3.2 区别

HashMap 和 Hashtable 的主要区别是:

  1. Hashtable 是线程安全的,HashMap 是线程不安全的,主要原因是 Hashtable 的主要方法都加了 synchronized锁,实现了访问互斥。
  2. HashMap 的 key 和 value 都允许为 null,Hashtable 的 key 和 value 都不允许为空。

3.3 应用场景

HashMap 用于非并发场景,Hashtable 用于并发场景,但是并发场景推荐使用concurrentHashMap。

4.ConcurrentHashMap的原理、应用场景

4.1 原理

  1. ConcurrentHashMap 的底层结构也是 基于 数组+链表 实现的,数组用于存储链表的链表头,链表节点包含 key、value、hash值、next变量等,每次新插入的元素都会添加到对应下标的链表末尾,当链表长度超过 8 时,链表将转化为红黑树。
  2. ConcurrentHashMap 跟 Hashtable 一样是线程安全的,但是 ConcurrentHashMap 的锁是细粒度锁,需要进行修改操作时,它只对数组的一项进行加锁,而不是对整个数组加锁。

4.2 应用场景

多线程情况下对 HashMap 进行添加、删除操作时使用。虽然 Hashtable 和 ConcurrentHashMap 的应用场景差不多,但是还是尽量使用 ConcurrentHashMap。

5.ArrayList和LinkedList的区别?原理?应用场景?

5.1 ArrayList原理

小学生也能看懂的ArrayList底层原理_怎么看arraylist的底层_星空是梦想的博客-CSDN博客

ArrayList 底层使用 char数组 实现,除了数组,还有一个记录数组大小的 size 变量,添加数组元素时,当数组已满时,会进行扩容,将容量扩大为 1.5 倍。

5.2 LinkedList原理

学透 LinkedList 底层实现原理,狂虐面试官!_星空是梦想的博客-CSDN博客

LinkedList 底层使用 双向链表 实现,LinkedList类中有头节点(first)、尾节点(last)和记录链表长度的 size。

LinkedList 的节点结构为:item(存储节点值)、next(存储下一个节点)和 prev(存储上一个节点)。

5.3 两者区别

  • ArrayList 使用char数组实现,LinkedList 使用链表实现;
  • ArrayList 和 LinkedList 都是非线程安全的;
  • 随机 get 和 set 访问,ArrayList 比 LinkedList 好,因为 LinkedList 访问要移动指针;
  • 插入和删除操作,LinkedList 比 ArrayList 好,因为 ArrayList 要大量移动数据。

5.4 应用场景

  • 如果涉及到“栈”、“队列”、“链表”等操作,应该选择使用 List;

  • 如果需要快速删除、插入元素,应该使用 LinkedList ;

  • 如果需要快速访问元素,应该使用 ArrayList。

6.String、StringBuilder和StringBuffer的区别,应用场景

6.1 运行速度比较

运行速度测试代码

StringBuilder > StringBuffer > String

解释:

创建 String 对象后,因为 String 对象是不可变的,每次需要改变 String 的值,都要重新建立一个新对象,再将引用指向该对象,浪费内存,而且无用对象多了 jvm 会引发 GC,系统就变慢了。

StringBuilder 和 StringBuffer 是可变的字符串变量,在进行字符串拼接时,不会创建新对象,而是直接对原对象进行操作,速度上比 String 拼接快很多;另外,由于 StringBuffer 底层实现都加了 synchronized 修饰,执行速度上稍微比 StringBuilder 慢一点。

6.2 是否线程安全

  • StringBuilder 是线程不安全的;
  • StringBuffer 是线程安全的。

解释:

StringBuffer 底层的很多方法(例如append 和 inser)都使用 synchronized 关键字修饰,保证了多线程情境下的线程安全。

6.3 适用场景

  • String:适用于少量字符串操作情况。
  • StringBulider:适用于单线程在字符串缓存区进行大量操作。
  • StringBuffer:适用于多线程在字符串缓存区进行大量操作。

6.4 底层实现

StringBuilder和StringBuffer:

  1. 底层使用 char数组 实现;
  2. append(str)方法:内部先判断 str 是否为空,为空的话在 char数组后添加“null”,不为空则将 str 拷贝到 char数组。

7.ArrayList和Vector的区别

7.1 相同点

ArrayList 和 Vector 都实现了List接口,都是有序可重复集合。

7.2 不同点

  • 线程安全:Vector是 线程安全 的,也就是说是它的方法之间是线程同步的;ArrayList是 线程序不安全 的,它的方法之间是线程不同步的。
  • 动态扩容倍数:当存储空间不足时,两种都会动态增长。Vector增长为原来的 2 倍,ArrayList增加为原来的 1.5 倍。

8.Collection下有哪些子类

List

  • Vector
  • ArrayList
  • LinkedList

Set

  • HashSet
  • TreeSet

9.Comparable和Comparator的区别

  1. Comparable和Comparator都可以实现对象比较和对象集合的排序。
  2. 类通过实现Comparable接口和compareTo方法,实现比较逻辑,可以实现和同个类对象进行比较,通过Collections.sort(List)实现类集合的排序。
  3. Comparator可以不改变类本身而进行比较和排序,需要创建另一个类实现该接口,然后实现compareTo方法,对目标类进行比较,另外,可以使用Collections.sort(List, Comparator)对类集合进行排序。

 

 

 

 

 

 

 

 

相关文章:

Java数据结构面试题以及答案

本专栏记录Java后端开发相关的面试题,欢迎大家阅读专栏的其他文章。 目录 1.B树和B树的区别?B树和B树的优点分别是? 2.排序算法的种类和复杂度 3.HashMap和Hashtable的原理、区别、应用场景 4.ConcurrentHashMap的原理、应用场景 5.Arra…...

Java——它要求用户输入一个整数(实际上是一个字符串),然后计算该整数的平方值,并将结果输出。

这是一个Java程序,它要求用户输入一个整数(实际上是一个字符串),然后计算该整数的平方值,并将结果输出。程序的基本流程如下: 首先,声明并初始化变量data和result,它们的初始值都为…...

【科研论文配图绘制】task6直方图绘制

【科研论文配图绘制】task6直方图绘制 task6 主要掌握直方图的绘制技巧,了解直方图含义,清楚统计指标的添加方式 1.直方图 直方图是一种用于表示数据分布和离散情况的统计图形,它的外观和柱形图相近,但它所 表达的含义和柱形图…...

Leetcode刷题:395. 至少有 K 个重复字符的最长子串、823. 带因子的二叉树

Leetcode刷题:395. 至少有 K 个重复字符的最长子串、823. 带因子的二叉树 1. 395. 至少有 K 个重复字符的最长子串算法思路参考代码和运行结果 2. 823. 带因子的二叉树算法思路参考代码和运行结果 1. 395. 至少有 K 个重复字符的最长子串 题目难度:中等 标签&#…...

java八股文面试[多线程]——Synchronized的底层实现原理

笔试:画出Synchronized 线程状态流转实现原理图 synchronized关键字解决的是多个线程之间访问资源的同步性,synchronized 翻译为中文的意思是同步,也称之为”同步锁“。 synchronized的作用是保证在同一时刻, 被修饰的代码块或方…...

C#,《小白学程序》第三课:类、类数组与排序

类class把数值与功能巧妙的进行了结合&#xff0c;是编程技术的主要进步。 下面的程序你可以确立 分数 与 姓名 之间关系&#xff0c;并排序。 1 文本格式 /// <summary> /// 同学信息类 /// </summary> public class Classmate { /// <summary> /…...

史上最全AP、mAP详解与代码实现

文章目录 前言一、mAP原理1、mAP概念2、准确率3、精确率4、召回率5、AP: Average Precision 二、mAP0.5与mAP0.5:0.951、mAP0.52、mAP0.5:0.95 三、mAP代码实现1、真实标签json文件格式2、模型预测标签json文件格式3、mAP代码实现4、mAP结果显示 四、模型集成mAP代码1、模型mai…...

百数应用中心——生产制造管理解决方案解决行业难题

传统生产制造业面临着许多挑战&#xff0c;其中一些主要问题包括效率低下、交期压力大、需求预测不准确、生产模式复杂、异常响应慢、库存高和计划脱节等。这些问题不仅影响了生产效率和质量&#xff0c;也导致了不必要的成本和客户满意度下降。 生产制造管理应用对于企业的生产…...

《存储IO路径》专题:IO虚拟化初探

大家好&#xff0c;欢迎来到今天的科技小课堂。今天我们要聊聊的是一项非常有趣且实用的技术——I/O虚拟化&#xff08;Input/Output Virtualization&#xff0c;简称IOV&#xff09;。想象一下&#xff0c;如果把物理硬件资源比作一道丰盛的大餐&#xff0c;那么IOV就是那位神…...

Springboot2.0快速入门(第一章)

目录 一&#xff0c;SpringBoot简介1.1&#xff0c;回顾什么是Spring1.2&#xff0c;Spring是如何简化Java开发的1.3&#xff0c;什么是SpringBoot 二&#xff0c;Hello&#xff0c;World2.1&#xff0c;准备工作2.2&#xff0c;创建基础项目说明2.3&#xff0c;创建第一个Hell…...

Flink流批一体计算(17):PyFlink DataStream API之StreamExecutionEnvironment

目录 StreamExecutionEnvironment Watermark watermark策略简介 使用 Watermark 策略 内置水印生成器 处理空闲数据源 算子处理 Watermark 的方式 创建DataStream的方式 通过list对象创建 ​​​​​​使用DataStream connectors创建 使用Table & SQL connectors…...

javeee spring cglib动态代理

cglib动态代理 依赖 <dependency><groupId>cglib</groupId><artifactId>cglib-nodep</artifactId><version>3.2.4</version></dependency>代理类 package com.test.cglibProxy;import net.sf.cglib.proxy.Enhancer; import …...

【Docker】Dockerfile介绍

Dockerfile是一个文本文件&#xff0c;其中包含了一系列的指令&#xff0c;用于构建Docker镜像。这些指令可以用来自动化镜像的构建过程&#xff0c;并创建自定义镜像。 以下是一些常用的Dockerfile指令及其功能&#xff1a; FROM&#xff1a;指定基础镜像。这是Dockerfile中…...

两个hdfs之间迁移传输数据

本文参考其他大数据大牛的博文做了整理和实际验证&#xff0c;主要解决hdfs跨集群复制/迁移问题。 在hdfs数据迁移时总会涉及到两个hdfs版本版本问题&#xff0c;致力解决hdfs版本相同和不同两种情况的处理方式&#xff0c;长话短说&#xff0c;进正文。 distcp: hadoop自带的…...

C++ 缺失的数字

有n个数字&#xff0c;值就是1~n&#xff0c;现发现丢失了2个数字&#xff0c;请你根据剩余的n-2个数字&#xff0c;编程计算一下&#xff0c;缺失的是哪两个数字呢&#xff1f; &#xff08;使用桶排&#xff0c;标记输入过的数字&#xff09; #include<bits/stdc.h> us…...

JVM,JRE和JDK的区别

JVM&#xff0c;JRE和JDK的区别 JVM(Java Virtual Machine&#xff0c;Java虚拟机)JREJRE目录结构 JDK JVM(Java Virtual Machine&#xff0c;Java虚拟机) Java程序的跨平台特性主要是指字节码文件可以在任何具有Java虚拟机的计算机或者电子设备上运行&#xff0c;Java虚拟机中…...

合宙Air724UG LuatOS-Air LVGL API控件--日历 (Calendar)

日历 (Calendar) LVGL 提供了一个用来选择和显示当前日期的日历控件。 示例代码 – 高亮显示的日期 highlightDate lvgl.calendar_date_t() – 日历点击的回调函数 – 将点击日期设置高亮 function event_handler(obj, event) if event lvgl.EVENT_VALUE_CHANGED then da…...

[python]问题:pandas处理excel里的多个sheet

Pandas 可以很容易地处理 Excel 文件中的多个工作表。首先,你需要安装 pandas 和 openpyxl(用于读取 .xlsx 文件)库。你可以使用以下命令安装这两个库: pip install pandas openpyxl接下来,你可以使用以下代码来处理 Excel 文件中的多个工作表: import pandas as pd# 读…...

[MySQL] MySQL基础操作汇总

文章目录 前言1.数据库概述1.1 数据库相关概念1.2登录MySQL&#xff1a;1.3 MySQL常用命令1.4表&#xff1a;1.5SQL语句分类&#xff1a; 2.CRUD操作2.1 DQL1.基础查询基础查询&#xff08;简单查询&#xff09;条件查询&#xff1a;排序查询&#xff1a;分组查询&#xff1a;分…...

C语言每日一题 ---- 打印从1到最大的n位数(Day 1)

本专栏为c语言练习专栏&#xff0c;适合刚刚学完c语言的初学者。本专栏每天会不定时更新&#xff0c;通过每天练习&#xff0c;进一步对c语言的重难点知识进行更深入的学习。 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;C语言天天练 &#x…...

装饰模式(Decorator Pattern)重构java邮件发奖系统实战

前言 现在我们有个如下的需求&#xff0c;设计一个邮件发奖的小系统&#xff0c; 需求 1.数据验证 → 2. 敏感信息加密 → 3. 日志记录 → 4. 实际发送邮件 装饰器模式&#xff08;Decorator Pattern&#xff09;允许向一个现有的对象添加新的功能&#xff0c;同时又不改变其…...

uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖

在前面的练习中&#xff0c;每个页面需要使用ref&#xff0c;onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入&#xff0c;需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...

Python爬虫(二):爬虫完整流程

爬虫完整流程详解&#xff08;7大核心步骤实战技巧&#xff09; 一、爬虫完整工作流程 以下是爬虫开发的完整流程&#xff0c;我将结合具体技术点和实战经验展开说明&#xff1a; 1. 目标分析与前期准备 网站技术分析&#xff1a; 使用浏览器开发者工具&#xff08;F12&…...

用docker来安装部署freeswitch记录

今天刚才测试一个callcenter的项目&#xff0c;所以尝试安装freeswitch 1、使用轩辕镜像 - 中国开发者首选的专业 Docker 镜像加速服务平台 编辑下面/etc/docker/daemon.json文件为 {"registry-mirrors": ["https://docker.xuanyuan.me"] }同时可以进入轩…...

Swagger和OpenApi的前世今生

Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章&#xff0c;二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑&#xff1a; &#x1f504; 一、起源与初创期&#xff1a;Swagger的诞生&#xff08;2010-2014&#xff09; 核心…...

2023赣州旅游投资集团

单选题 1.“不登高山&#xff0c;不知天之高也&#xff1b;不临深溪&#xff0c;不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据 Power Query 具有大量专门帮助您清理和准备数据以供分析的功能。 您将了解如何简化复杂模型、更改数据类型、重命名对象和透视数据。 您还将了解如何分析列&#xff0c;以便知晓哪些列包含有价值的数据&#xff0c;…...

华硕a豆14 Air香氛版,美学与科技的馨香融合

在快节奏的现代生活中&#xff0c;我们渴望一个能激发创想、愉悦感官的工作与生活伙伴&#xff0c;它不仅是冰冷的科技工具&#xff0c;更能触动我们内心深处的细腻情感。正是在这样的期许下&#xff0c;华硕a豆14 Air香氛版翩然而至&#xff0c;它以一种前所未有的方式&#x…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf

FTP 客服管理系统 实现kefu123登录&#xff0c;不允许匿名访问&#xff0c;kefu只能访问/data/kefu目录&#xff0c;不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

Java毕业设计:WML信息查询与后端信息发布系统开发

JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发&#xff0c;实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构&#xff0c;服务器端使用Java Servlet处理请求&#xff0c;数据库采用MySQL存储信息&#xff0…...