【LeetCode热题100】--1.两数之和

1.两数之和

【LeetCode热题100】--1.两数之和_第1张图片

方法一:最直观的方法就是暴力破解,就是枚举数组中的每一个数x,寻找数组中是否存在target-x

class Solution {
    public int[] twoSum(int[] nums, int target) {
        int n = nums.length;
        for(int i=0;i<n;i++){
            for(int j = i+1 ;j<n;j++){
                if(nums[i]+nums[j] == target){
                    return new int[]{i,j};
                }
            }
        }
        return new int[0];
    }
}
  • 时间复杂度: O ( N 2 ) O(N^2) O(N2)
  • 空间复杂度: O ( 1 ) O(1) O(1)

对于最后返回new int[0]返回一个长度为0的空数组

对于返回数组的题目,注意最后的返回值不能直接为null,可能的原因是为了更进一步的处理数组返回值,如果返回值为null,则任何方法都不能对其进行操作。

对于数组作为输入时的判断准则也应该分为两步:对于数组而言,不但要判断它是否为空指针,也需要判断它是否有内容,同时要先判断空指针再判断长度是否为0,顺序不能颠倒,因为空指针没有length属性。

方法二:利用哈希表

创建一个哈希表,对于每个x,首先查询哈希表中是否存在target-x,然后将x插入到哈希表中,即可保证不会让x和自己匹配

class Solution {
    public int[] twoSum(int[] nums, int target) {
        // 创建一个哈希表
        Map<Integer,Integer> hashtable = new HashMap<Integer,Integer>();
        for (int i = 0;i< nums.length;i++){
            //判断哈希表中是否存在target-x
            if(hashtable.containsKey(target - nums[i])){
                return new int[]{hashtable.get(target - nums[i]),i};
            }
            //将x插入到哈希表中
            hashtable.put(nums[i],i);
        }
        return new int[0];
    }
}

你可能感兴趣的:(LeetCode,leetcode,算法,数据结构)