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

1.两数之和

image-20230728231425709

方法一:最直观的方法就是暴力破解,就是枚举数组中的每一个数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];
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值