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 原理
- HashMap 和 Hashtable 的底层结构都是 数组+链表结构实现的。数组用于存储链表头节点,新增元素都会添加到对应位置的链表末尾,链表节点数量超过 8 时,链表会转化为红黑树。
- 它们的链表节点中有一个 hash 变量,用于存储该结点的 hash 值,通过 hash值 可以快速定位元素位置。
3.2 区别
HashMap 和 Hashtable 的主要区别是:
- Hashtable 是线程安全的,HashMap 是线程不安全的,主要原因是 Hashtable 的主要方法都加了 synchronized锁,实现了访问互斥。
- HashMap 的 key 和 value 都允许为 null,Hashtable 的 key 和 value 都不允许为空。
3.3 应用场景
HashMap 用于非并发场景,Hashtable 用于并发场景,但是并发场景推荐使用concurrentHashMap。
4.ConcurrentHashMap的原理、应用场景
4.1 原理
- ConcurrentHashMap 的底层结构也是 基于 数组+链表 实现的,数组用于存储链表的链表头,链表节点包含 key、value、hash值、next变量等,每次新插入的元素都会添加到对应下标的链表末尾,当链表长度超过 8 时,链表将转化为红黑树。
- 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:
- 底层使用 char数组 实现;
- 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的区别
- Comparable和Comparator都可以实现对象比较和对象集合的排序。
- 类通过实现Comparable接口和compareTo方法,实现比较逻辑,可以实现和同个类对象进行比较,通过Collections.sort(List)实现类集合的排序。
- 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把数值与功能巧妙的进行了结合,是编程技术的主要进步。 下面的程序你可以确立 分数 与 姓名 之间关系,并排序。 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…...
百数应用中心——生产制造管理解决方案解决行业难题
传统生产制造业面临着许多挑战,其中一些主要问题包括效率低下、交期压力大、需求预测不准确、生产模式复杂、异常响应慢、库存高和计划脱节等。这些问题不仅影响了生产效率和质量,也导致了不必要的成本和客户满意度下降。 生产制造管理应用对于企业的生产…...
《存储IO路径》专题:IO虚拟化初探
大家好,欢迎来到今天的科技小课堂。今天我们要聊聊的是一项非常有趣且实用的技术——I/O虚拟化(Input/Output Virtualization,简称IOV)。想象一下,如果把物理硬件资源比作一道丰盛的大餐,那么IOV就是那位神…...
Springboot2.0快速入门(第一章)
目录 一,SpringBoot简介1.1,回顾什么是Spring1.2,Spring是如何简化Java开发的1.3,什么是SpringBoot 二,Hello,World2.1,准备工作2.2,创建基础项目说明2.3,创建第一个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是一个文本文件,其中包含了一系列的指令,用于构建Docker镜像。这些指令可以用来自动化镜像的构建过程,并创建自定义镜像。 以下是一些常用的Dockerfile指令及其功能: FROM:指定基础镜像。这是Dockerfile中…...
两个hdfs之间迁移传输数据
本文参考其他大数据大牛的博文做了整理和实际验证,主要解决hdfs跨集群复制/迁移问题。 在hdfs数据迁移时总会涉及到两个hdfs版本版本问题,致力解决hdfs版本相同和不同两种情况的处理方式,长话短说,进正文。 distcp: hadoop自带的…...
C++ 缺失的数字
有n个数字,值就是1~n,现发现丢失了2个数字,请你根据剩余的n-2个数字,编程计算一下,缺失的是哪两个数字呢? (使用桶排,标记输入过的数字) #include<bits/stdc.h> us…...
JVM,JRE和JDK的区别
JVM,JRE和JDK的区别 JVM(Java Virtual Machine,Java虚拟机)JREJRE目录结构 JDK JVM(Java Virtual Machine,Java虚拟机) Java程序的跨平台特性主要是指字节码文件可以在任何具有Java虚拟机的计算机或者电子设备上运行,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:1.3 MySQL常用命令1.4表:1.5SQL语句分类: 2.CRUD操作2.1 DQL1.基础查询基础查询(简单查询)条件查询:排序查询:分组查询:分…...
C语言每日一题 ---- 打印从1到最大的n位数(Day 1)
本专栏为c语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C语言天天练 &#x…...
装饰模式(Decorator Pattern)重构java邮件发奖系统实战
前言 现在我们有个如下的需求,设计一个邮件发奖的小系统, 需求 1.数据验证 → 2. 敏感信息加密 → 3. 日志记录 → 4. 实际发送邮件 装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其…...
uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖
在前面的练习中,每个页面需要使用ref,onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入,需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...
Python爬虫(二):爬虫完整流程
爬虫完整流程详解(7大核心步骤实战技巧) 一、爬虫完整工作流程 以下是爬虫开发的完整流程,我将结合具体技术点和实战经验展开说明: 1. 目标分析与前期准备 网站技术分析: 使用浏览器开发者工具(F12&…...
用docker来安装部署freeswitch记录
今天刚才测试一个callcenter的项目,所以尝试安装freeswitch 1、使用轩辕镜像 - 中国开发者首选的专业 Docker 镜像加速服务平台 编辑下面/etc/docker/daemon.json文件为 {"registry-mirrors": ["https://docker.xuanyuan.me"] }同时可以进入轩…...
Swagger和OpenApi的前世今生
Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章,二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑: 🔄 一、起源与初创期:Swagger的诞生(2010-2014) 核心…...
2023赣州旅游投资集团
单选题 1.“不登高山,不知天之高也;不临深溪,不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...
微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据
微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据 Power Query 具有大量专门帮助您清理和准备数据以供分析的功能。 您将了解如何简化复杂模型、更改数据类型、重命名对象和透视数据。 您还将了解如何分析列,以便知晓哪些列包含有价值的数据,…...
华硕a豆14 Air香氛版,美学与科技的馨香融合
在快节奏的现代生活中,我们渴望一个能激发创想、愉悦感官的工作与生活伙伴,它不仅是冰冷的科技工具,更能触动我们内心深处的细腻情感。正是在这样的期许下,华硕a豆14 Air香氛版翩然而至,它以一种前所未有的方式&#x…...
LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf
FTP 客服管理系统 实现kefu123登录,不允许匿名访问,kefu只能访问/data/kefu目录,不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...
Java毕业设计:WML信息查询与后端信息发布系统开发
JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息࿰…...
