给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。

你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。

示例:

给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

分析
先理解题意,就是从一个数组里找出两个相加和为 target 的值,并返回数组的下标数组

题解一
直接遍历,有相加为 target 且两个数下标不相等返回

class Solution {
    public int[] twoSum(int[] nums, int target) {
        int len = nums.length;
        for(int i=0;i<len;i++)
            for(int j=0;j<len;j++)
                if(nums[i] + nums[j] == target && i!=j)
                    return new int[]{i,j};
        return null;
    }
}

题解二:
利用 Map(key,value) 的性质,将所有遍历过的数组值存为 key,所有数组下标存为 value,利用 containsKey 方法判断 Map 中是否含有该 key 值,如果有说明之前遍历过的数组值中存在和该数组值匹配(相加为 target)的值,则返回数组;否则继续设置当前 key 和 value ,进行下一轮遍历

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