力扣-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}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值