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

力扣-1.两数之和

题目描述

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。

你可以按任意顺序返回答案。

class Solution {public int[] twoSum(int[] nums, int target) {int[] res = new int[2];Map<Integer, Integer> map = new HashMap<>();for (int i = 0; i < nums.length; i++) {if (map.containsKey(target - nums[i])) {res[0] = map.get(target - nums[i]);res[1] = i;} else {map.put(nums[i], i);}}return res;}
}

小结:用Java二刷hot100的第一道题,因为一刷hot100用的是C++,发现Java竟然有些生疏了,这道题思路比较简单,有了一刷的的经验也是一下子就想到了哈希表,下面总结了Java Map相关的API还有一些遗忘的知识点。

Java Map常用API

方法/操作功能说明返回类型特性要点
put(key, value)键值对插入/更新(存在则覆盖)V返回旧值或 null,HashMap允许null键值
size()返回键值对数量int最大值为 Integer.MAX_VALUE
clear()清空所有元素void容量保留机制(如HashMap桶数组不重置)
isEmpty()判断集合空状态boolean等效逻辑:size() == 0
get(key)按键查值V可能返回null(需配合containsKey验证)
remove(key)删除指定键元素VJava 8+支持条件删除:remove(key, value)
containsKey(key)键存在性验证boolean哈希结构时间复杂度O(1)
containsValue(value)值存在性验证boolean全表扫描,时间复杂度O(n)
keySet()获取键集合视图Set<K>动态关联原数据(删除操作会同步)
values()获取值集合视图Collection<V>允许重复值,不可直接增删
putAll(map2)合并映射集(重复键覆盖)void非原子操作,线程不安全

Java不同Map的对比

特性HashMapLinkedHashMapTreeMapConcurrentHashMap
底层结构数组+链表/红黑树哈希表+双向链表红黑树分段锁+链表/红黑树
数据顺序完全无序插入顺序/访问顺序键的自然或定制排序无序
线程安全✅(CAS+分段锁)
允许null键/值✅/✅✅/✅❌/✅❌/❌
时间复杂度O(1)(平均)O(1)(访问)O(log n)O(1)(高并发优化)
内存占用中(维护链表)高(树节点)中(分段存储)
典型场景高频随机读写缓存淘汰策略范围查询/排序需求高并发计数/缓存

Java 数组初始化

  • 静态初始化数组
int[] ages = new int[]{12, 24, 36};
int[] ages = {12, 24, 36};
  • 动态初始化数组
int[] ages = new int[3]; // {0, 0, 0}
http://www.xdnf.cn/news/5915.html

相关文章:

  • java的switch case
  • Flutter小白入门指南
  • Spark Streaming 内部运行机制详解
  • MySQL 深度分页怎么优化?
  • 基于 Spring Boot 瑞吉外卖系统开发(十三)
  • SpringBoot中的拦截器
  • 精简大语言模型:用于定制语言模型的自适应知识蒸馏
  • RobotxR1:通过闭环强化学习在大语言模型上实现具身机器人智能
  • 【Web应用】Vue 项目前端项目文件夹和文件介绍
  • 17.责任链模式:思考与解读
  • Mysql索引优化
  • State(状态)——对象行为型模式
  • 在scala中sparkSQL读入csv文件
  • 【AI提示词】贝叶斯分析专家
  • C语言编程--二叉树--构建解析树
  • iOS - 如何从appStore获取app版本信息
  • 各类芒果(果实、叶片、产量等)相关数据集
  • Python爬虫实战:研究JavaScript 环境补全逆向解密
  • SQLMesh信号机制详解:如何精准控制模型评估时机
  • CSS可以继承的样式汇总
  • 【言语】刷题3
  • 串口模块详细讲解
  • IO、存储、硬盘、文件系统相关常识
  • 【Bluedroid】蓝牙 HID DEVICE 初始化流程源码解析
  • 十天学会嵌入式技术之51单片机—day-9
  • 【技巧】使用UV创建python项目的开发环境
  • 面试篇:Spring Security
  • C语言—再学习(数据的存储类别)
  • C++ 字符格式化输出
  • python学习笔记七(文件)