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

力扣-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}

相关文章:

  • ubuntu---100条常用命令
  • 基于AI的报告平台
  • [SAP] 通过事务码Tcode获取程序名
  • Linux字体遍历 获取支持的unicode范围
  • Windows Java gRPC 示例
  • 音频特征工具Librosa包的使用
  • 在Window上面添加交叉编译链 MinGW+NDK
  • jackson-dataformat-xml引入使用后,响应体全是xml
  • 3.1 泰勒公式出发点
  • 9.9 Ollama私有化部署Mistral 7B全指南:命令行交互到API集成全流程解析
  • “端 - 边 - 云”三级智能协同平台的理论建构与技术实现
  • 组合问题(多条件)
  • AWS IoT Core自定义域名配置实战指南
  • 某实战项目登录口处的渗透测试
  • 机器学习 --- 特征工程(一)
  • redis数据结构-09 (ZADD、ZRANGE、ZRANK)
  • 线代第二章矩阵第八节逆矩阵、解矩阵方程
  • 脑机接口技术:开启人类与机器融合的新时代
  • Gatsby知识框架
  • 软考架构师考试-UML图总结
  • 时隔5个月,辽沈银行行长再调整
  • 联合国妇女署:超过2.8万名妇女和女童在加沙战火中丧生
  • 夜读丨永不掉电的陪伴
  • 英伟达推出新技术加速AI芯片连接,期望构建互联互通生态
  • 一座与人才共成长的理想之城,浙江嘉兴为何如此吸引人?
  • 脱欧后首次英欧峰会召开前夕,双方却因渔业和青年流动议题僵住了