【华为OD技术面试真题 - 技术面】- Java面试题(4)

本文汇总了华为OD技术面试中的Java核心概念,包括数组和链表的使用场景及其优缺点,单向链表倒数第k个节点的查找,选择排序的稳定性,HashMap的底层原理,优先级队列的介绍,Java NIO概述,以及多线程创建和同步方式。通过这些面试题,深入理解Java编程和数据结构的关键点。

华为OD面试真题题库

专栏:华为OD面试真题题库
目录: 最新华为OD面试手撕代码真题目录以及八股文真题目录

封面

1. 请谈谈在Java开发中,数组和链表的使用场景及优缺点。

数组是一种线性数据结构,它可以在内存中连续存储多个相同类型的元素。数组的优点是访问元素的时间复杂度为O(1),即通过索引可以直接访问到指定位置的元素。这使得数组在需要频繁访问元素的场景下非常高效。另外,数组的内存分配是连续的,因此在空间上相对紧凑,对于大量元素的存储比较节省内存。然而,数组的缺点是大小固定,一旦创建后大小不可变。如果需要动态地插入或删除元素,就需要进行元素的搬移操作,这会带来一定的时间开销。

链表是一种非连续的数据结构,它由一系列的节点组成,每个节点包含一个数据元素和一个指向下一个节点的引用。链表的优点是可以动态地插入和删除元素,不需要像数组那样进行元素的搬移操作,因此在频繁插入和删除元素的场景下比较高效。另外,链表的大小可以动态调整,不受固定大小的限制。然而,链表的缺点是访问元素的时间复杂度为O(n),即需要从头节点开始遍历链表才能找到指定位置的元素。这使得链表在需要频繁访问元素的场景下效率较低。此外,链表需要额外的空间来存储节点之间的引用,相对于数组来说,对内存的占用会更多一些。

综上所述,数组适用于需要频繁访问元素、大小固定的场景,而链表适用于需要频繁插入和删除元素、大小不固定的场景。

2. 找到单向链表的倒数第k个节点(不统计链表长度的前提下),并返回该节点

使用双指针法来解决问题。首先,我们让fast指针先向前移动k个位置,然后同时移动slow和fast指针,直到fast指针到达链表末尾。此时,slow指针所指的节点就是倒数第k个节点。如果链表长度小于k,即fast指针在移动过程中到达了链表末尾,那么返回null。

下面是一个示例的Java函数实现,用于找到单向链表的倒数第k个节点:

public ListNode findKthFromEnd(ListNode head, int k) {
   
   
    ListNode slow = head;
    ListNode fast = head;
    
    // 先让fast指针向前移动k个位置
    for 
### 华为OD技术面试真实题目及答案 #### 技术常见问题与解答 #### 跨域请求解决方案 在前端开发中,跨域请求问题是常见的挑战之一。以下是几种常用的解决跨域问题的方法: - **CORS(跨源资源共享)** CORS是一种基于HTTP头的机制,允许服务器声明哪些资源可以被其他域名下的页访问。通过设置`Access-Control-Allow-Origin`响应头来指定允许访问该资源的外部域名[^2]。 ```javascript // 浏览器发起跨域请求的例子 fetch('https://api.example.com/data', { method: 'GET', mode: 'cors' }) .then(response => response.json()) .then(data => console.log(data)); ``` #### Java基础知识问答 关于Java的基础知识也是华为OD技术面试中的一个重要部分。下是一些典型的问题及其解答: - **Java堆栈的概念** Java程序运行时会创建两种类型的内存区域:堆和栈。其中,**栈(Stack)**用于存储局部变量、方法参数以及返回地址等短期存在的数据;而**堆(Heap)**则用来保存对象实例和其他动态分配的数据结构。两者的主要区别在于生命周期管理和垃圾回收机制的不同[^3]。 - **线程安全的Map实现类** 在多线程环境中使用的线程安全映射表主要有以下几种: - `ConcurrentHashMap`: 提供高效的并发读写操作支持; - `Hashtable`: 是较早版本中提供的同步化哈希表容器; - `Collections.synchronizedMap()`: 可以将任意Map转换成具有基本同步特性的新Map实例。 - **常用的数据结构** 对于日常工作或算法练习来说,经常接触到的一些重要Java集合框架成员包括但不限于: - List接口下实现了数组列表(`ArrayList`)、链表(`LinkedList`); - Set接口提供了不可重复元素集合的功能, 如HashSet; - Map接口定义了键值对关联关系, 上述提到过的ConcurrentHashMap就是其一种具体形式. - **ArrayList特性** ArrayList内部采用连续空间存储元素,默认情况下按照插入顺序保持稳定排列,因此它是**有序**的序列容器. ```java List<String> list = new ArrayList<>(); list.add("first"); list.add("second"); System.out.println(list); // 输出:[first, second] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

算法大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值