为了账号安全,请及时绑定邮箱和手机立即绑定

一道使用算法解决的java题(关于hashmap的问题)

一道使用算法解决的java题(关于hashmap的问题)

DIEA 2019-03-01 11:00:36
leetcode的第一题,这种方法可以实现O(n)复杂度解 题目要求是给一个int[],例如 nums = [2, 7, 11, 15],给一个target = 9。若存在两个数的和为target值,例如 nums[0] + nums[1] = 2 + 7 = 9return [0, 1]. 使用如下解法的时候,有一点疑惑,就是new了一个hashmap,但是并没有给他赋值,这种情况下是如何实现题目要求的呢? public int[] twoSum(int[] numbers, int target) { int[] result = new int[2]; Map<Integer, Integer> map = new HashMap<Integer, Integer>(); for (int i = 0; i < numbers.length; i++) { if (map.containsKey(target - numbers[i])) { result[1] = i + 1; result[0] = map.get(target - numbers[i]); return result; } map.put(numbers[i], i + 1); } return result; }
查看完整描述

3 回答

?
临摹微笑

TA贡献1982条经验 获得超2个赞

没有 Key 的情况下,HashMap.containsKey(Key) 返回的是 false 不包括 Key

    public boolean containsKey(Object key) {
        return getNode(hash(key), key) != null;
    }

不会出现你所想的空指针错误。

查看完整回答
反对 回复 2019-03-01
?
米脂

TA贡献1836条经验 获得超3个赞

for循环里面的map.put()不是赋值吗???

查看完整回答
反对 回复 2019-03-01
  • 3 回答
  • 0 关注
  • 427 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号