一、审题
1、描述:
2、题意:
求两数和为 target 的这两数下标
二、解答
若采用循环需要两层for,考虑用 Map 的 key 记录值,value 记录其所在下标,则时间复杂度为 n;
class Solution { public int[] twoSum(int[] nums, int target) { int[] result; int index = 0; Map<Integer, Integer> map = new HashMap<Integer, Integer>(); for (int i = 0; i < nums.length; i++) { if(map.containsKey(target - nums[i])) { // 判断 map 中 是否包含了另一个值 result = new int[]{map.get(target - nums[i]), i}; return result; } map.put(nums[i], i); } return null; } }