给定一个整数数组 nums 和一个目标值 target, 请你在该数组中找出和为目标值的 两个 整数.
你可以假设每种输入只会对应一个答案. 但是, 你不能重复利用这个数组中同样的元素.
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
通过使用空间换取时间, 降低时间复杂度
时间复杂度 O(n)
空间复杂度 o(n)
- public int[] twoSum(int[] nums, int target) {
- Map<Integer, Integer> map = new HashMap<>();
- for (int i = 0; i < nums.length; i++) {
- int complement = target - nums[i];
- if (map.containsKey(complement)) {
- return new int[] { map.get(complement), i };
- }
- map.put(nums[i], i);
- }
- throw new IllegalArgumentException("No two sum solution");
- }
来源: http://www.bubuko.com/infodetail-2869225.html