1. 两数之和
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
法一:
1 public class Solution { 2 public int[] twoSum(int[] nums, int target) { 3 for (int i = 0; i < nums.length; i++) { 4 for (int j = i + 1; j < nums.length; j++) { 5 if (nums[i] + nums[j] == target) 6 return new int[] { i , j }; 7 } 8 } 9 return new int[]{ -1}; 10 } 11 }
暴力破解,循环相加
法二:
1 public class Solution2 { 2 public int[] twoSum(int[] nums, int target) { 3 HashMap<Integer ,Integer> map = new HashMap<>(); 4 for (int i = 0; i < nums.length; i++) { 5 map.put(nums[i] , i); 6 } 7 for (int i = 0; i < nums.length; i++) { 8 int a = target - nums[i]; 9 if (map.containsKey(a) && map.get(a) != i) 10 return new int[] { i, map.get(a)}; 11 } 12 return new int[] {-1}; 13 } 14 }
利用map存一个加数和该序列号,在遍历另一个加数。注意要判定序列号是否重合!
浙公网安备 33010602011771号