LeetCode - 兩數之和

連接: 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("");
  }
}

image-20191206085247799.png

利用HashMap

其實咱們只須要遍歷一次這個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("");
  }
}

 6iT2Ra4knGIvXBZ.png


總結一下

  • 上一次作ACM -- HDOJ 已是一年半之前了,十分生疏
  • 過分依賴IDE,第一次提交前編譯錯誤了3次!
  • 審題不仔細,居然忽略了每種輸入只有一個答案這樣的關鍵字,致使本身寫了一個可變數組

天天進步一點點!io

相關文章
相關標籤/搜索