博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode 1.两数之和
阅读量:5997 次
发布时间:2019-06-20

本文共 1954 字,大约阅读时间需要 6 分钟。

给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。

你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。

示例:

给定 nums = [2, 7, 11, 15], target = 9因为 nums[0] + nums[1] = 2 + 7 = 9所以返回 [0, 1] 自己编写代码: class Solution {
    public int[] twoSum(int[] nums, int target) {
        int numReturn[]=new int[2];         for (int i=0;i

官方给出解决方案


方法一:暴力法

暴力法很简单。遍历每个元素 xxx,并查找是否存在一个值与 target−xtarget - xtargetx 相等的目标元素。

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

    for (int i = 0; i < nums.length; i++) {
        for (int j = i + 1; j < nums.length; j++) {
            if (nums[j] == target - nums[i]) {
                return new int[] { i, j };
            }
        }
    }
    throw new IllegalArgumentException("No two sum solution");
}


方法二:两遍哈希表

为了对运行时间复杂度进行优化,我们需要一种更有效的方法来检查数组中是否存在目标元素。如果存在,我们需要找出它的索引。保持数组中的每个元素与其索引相互对应的最好方法是什么?哈希表。

通过以空间换取速度的方式,我们可以将查找时间从 O(n)O(n)O(n) 降低到 O(1)O(1)O(1)。哈希表正是为此目的而构建的,它支持以 近似 恒定的时间进行快速查找。我用“近似”来描述,是因为一旦出现冲突,查找用时可能会退化到 O(n)O(n)O(n)。但只要你仔细地挑选哈希函数,在哈希表中进行查找的用时应当被摊销为 O(1)O(1)O(1)。

一个简单的实现使用了两次迭代。在第一次迭代中,我们将每个元素的值和它的索引添加到表中。然后,在第二次迭代中,我们将检查每个元素所对应的目标元素(target−nums[i]target - nums[i]targetnums[i])是否存在于表中。注意,该目标元素不能是 nums[i]nums[i]nums[i] 本身!

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

    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 complement = target - nums[i];
        if (map.containsKey(complement) && map.get(complement) != i) {
            return new int[] { i, map.get(complement) };
        }
    }
    throw new IllegalArgumentException("No two sum solution");
}


方法三:一遍哈希表

事实证明,我们可以一次完成。在进行迭代并将元素插入到表中的同时,我们还会回过头来检查表中是否已经存在当前元素所对应的目标元素。如果它存在,那我们已经找到了对应解,并立即将其返回。

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

    Map<Integer, Integer> map = new HashMap<>();
    for (int i = 0; i < nums.length; i++) {
        int complement = target - nums[i];
        if (map.containsKey(complement)) {
            return new int[] { map.get(complement), i };
        }
        map.put(nums[i], i);
    }
    throw new IllegalArgumentException("No two sum solution");
}

转载于:https://www.cnblogs.com/TeFuir/p/9403876.html

你可能感兴趣的文章
python 使用__neg__和__iter__
查看>>
C# WinForm程序处理后台繁忙导致前台控件假死现象解决方法
查看>>
web api 初体验 解决js调用跨域问题
查看>>
ubuntu 系统启动异常之无登录界面和版本号启动四个点的地方卡住
查看>>
【软工】第 二 次作业(结对项目)
查看>>
ERP结账不自动清台的解决办法
查看>>
MATLAB产生离散信号
查看>>
触摸事件
查看>>
第三次立会啦
查看>>
-----第一讲----第二节--------------什么是算法?-------------------------------------
查看>>
计算机网络知识点总结
查看>>
php入门学习相关函数
查看>>
AC日记——友好城市 洛谷 P2782
查看>>
Windows Azure Active Directory正式发布:已提供了超过 2650 亿个身份验证和服务了290万个组织!...
查看>>
汇编语言(王爽)-第十章
查看>>
正则表达式全局匹配网址
查看>>
Python环境搭建
查看>>
Java 日志
查看>>
QML学习笔记(八)— QML实现列表侧滑覆盖按钮
查看>>
程序员面试笔试宝典学习记录(五)(操作系统相关知识)
查看>>