連接: https://leetcode-cn.com/probl...
給定一個整數數組 nums 和一個目標值 target,請你在該數組中找出和爲目標值的那 兩個 整數,並返回他們的數組下標。你能夠假設每種輸入只會對應一個答案。可是,你不能重複利用這個數組中一樣的元素。java
示例:數組
給定 nums = [2, 7, 11, 15], target = 9spa
由於 nums[0] + nums[1] = 2 + 7 = 9
因此返回 [0, 1]code
第一道題,八次提交,三次解答錯誤,一次編譯錯誤blog
我寫了兩種解法leetcode
這個簡單,不過期間複雜度時O(N^2),空間複雜度時O(1)rem
class Solution { public int[] twoSum(int[] nums, int target) { for(int i = 0; i<nums.length-1; i++) { for(int j = i+1; j<nums.length; j++) { if(nums[i] + nums[j] == target) { // 題目說明只有一個返回值,因此直接就能夠返回了 return new int[]{i, j}; } } } throw new RuntimeException(""); } }
其實咱們只須要遍歷一次這個nums,而後將nums[i]做爲key、i做爲value放到HashMap中,在放以前,檢查一下又沒有一個key是等於target-num[i]的,若是等於,就能夠立馬返回結果了get
這樣的時間複雜度是O(N),空間複雜度是O(N)it
class Solution { public int[] twoSum(int[] nums, int target) { Map<Integer,Integer> map = new HashMap<>(); map.put(nums[0],0); for(int i = 1; i<nums.length; i++) { if(map.containsKey(target-nums[i])) { return new int[]{map.get(target-nums[i]),i}; } map.put(nums[i],i); } throw new RuntimeException(""); } }
天天進步一點點!io