LeetCode算法一题型一以及解答。

题目:

  给定一个整数数列,找出其中和为特定值的那两个数。

  你可以假设每个输入都只会有一种答案,同样的元素不能被重用。

分析:

普遍方法是直接遍历两遍数组,第一遍用target-nums[i],第二遍找nums数组中是否存在target-nums[i]这个数字,找到就返回两个数字组成的数组,这个方法时间复杂度比较大为O(n²)

 

class Solution {

    public int[] twoSum(int[] nums, int target) {

    int[] result = new int[2];

        for (int i = 0; i < nums.length; i++) { 

            int v = target - nums[i]; 

            for (int j = 0; j < nums.length; j++) { 

                if (nums[j] == v && j != i){ 

                    result[0] = i; 

                    result[1] = j; 

                    return result; 

                } 

            } 

        } 

    return result;

    }

}

 还有可以用哈希表先把数组中的数字和对应的下标存储一遍,即数字作为键,下标作为值,存储,当遍历数组的时候用target-nums[i],得到差k,然后在map中找是否存在 k,找到即返回k所对应的value,也就是所对应的数组下标。这样时间复杂度就为O(n+l),快了好多

   //哈希表存储查找 

    class Solution { 

        public int[] twoSum(int[] nums, int target) { 

            int[] result = new int[2]; 

            Map<Integer,Integer> map = new HashMap<>(); 

            for (int i = 0; i < nums.length; i++) 

                map.put(nums[i],i); 

     

            for (int i = 0; i < nums.length; i++) { 

                int v = target - nums[i]; 

                if (map.containsKey(v) && i != map.get(v)){ 

                    result[0] = i; 

                    result[1] = map.get(v); 

                    return result; 

                } 

            } 

            return result; 

        } 

}

转载于:https://www.cnblogs.com/yswyzh/p/8656860.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值