LeetCode 1. 两数之和 Two Sum「建议收藏」

LeetCode 1. 两数之和 Two Sum「建议收藏」给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。示例:给定nums=[2,7,11,15],target=9因为nums[0]+nums[1]=2+7=9所以返回[0,1] 解决方案方法一:暴力法暴力法很简单。遍历每个元素xxx,并查找是否…

大家好,又见面了,我是你们的朋友全栈君。

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

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

示例:

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

 

解决方案


方法一:暴力法

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

复杂度分析:

  • 时间复杂度:O(n2)O(n^2)O(n​2​​), 对于每个元素,我们试图通过遍历数组的其余部分来寻找它所对应的目标元素,这将耗费 O(n)O(n)O(n) 的时间。因此时间复杂度为 O(n2)O(n^2)O(n​2​​)。

  • 空间复杂度:O(1)O(1)O(1)。
     


方法二:两遍哈希表

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

通过以空间换取速度的方式,我们可以将查找时间从 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]target−nums[i])是否存在于表中。注意,该目标元素不能是 nums[i]nums[i]nums[i] 本身!

复杂度分析:

  • 时间复杂度:O(n)O(n)O(n), 我们把包含有 nnn 个元素的列表遍历两次。由于哈希表将查找时间缩短到 O(1)O(1)O(1) ,所以时间复杂度为 O(n)O(n)O(n)。

  • 空间复杂度:O(n)O(n)O(n), 所需的额外空间取决于哈希表中存储的元素数量,该表中存储了 nnn 个元素。
     


方法三:一遍哈希表

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

复杂度分析:

  • 时间复杂度:O(n)O(n)O(n), 我们只遍历了包含有 nnn 个元素的列表一次。在表中进行的每次查找只花费 O(1)O(1)O(1) 的时间。

  • 空间复杂度:O(n)O(n)O(n), 所需的额外空间取决于哈希表中存储的元素数量,该表最多需要存储 nnn 个元素。

import java.util.*;

public class Solution {
    public int[] twoSum(int[] nums, int target) {
       int nums_length = nums.length;
       TwoSum[] tss = new TwoSum[nums_length];
       for(int i = 0; i<nums_length; ++i){
           tss[i] = new TwoSum(nums[i],i + 1);
       }
       Arrays.sort(tss);
       int[] result = new int[2];
       int begin = 0;
       int end = nums_length - 1;
       while(begin < end){
           if((tss[begin].number + tss[end].number) < target){
               begin++;
           }else if((tss[begin].number + tss[end].number) > target){
               end--;
           }else{
               if(tss[begin].idex > tss[end].idex){
                   result[0] = tss[end].idex;
                   result[1] = tss[begin].idex;
               }else{
                   result[0] = tss[begin].idex;
                   result[1] = tss[end].idex;
               }
               break;
           }
       }
       return result;
    }
}
class TwoSum implements Comparable<TwoSum>{
    public int number;
    public int idex;
    public TwoSum(int number,int idex){
        this.number = number;
        this.idex = idex;
    }
    
    public int compareTo(TwoSum model){
        return this.number - model.number;
    }
}

  执行效率比较慢,稍后优化

LeetCode 1. 两数之和 Two Sum「建议收藏」

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137365.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 程序员周六给心爱的“她”放电的动人故事「建议收藏」

    文章目录0x000x010x020x030x040x00注:此文是一篇流水扯淡文,我和她的故事。你的她还好吗?你有没有遇到过喜欢的她,昨天对你还眉开目笑,含情脉脉,今天就爱搭不理,毫无兴趣。不管你有没有遇到,反正我遇到了。我说的她不是你想的她,我说的她是有着15.6寸1080P超清的容颜的我的“acer 笔记本”。前段时间刚刚换的新的电池,然而今天一拔掉电源线,她就自动关机,根据不给我一点点面子,让我倍感无奈和忧伤~今天是周六,没有“Jack 马”口中福报的我,这一天本该是简单且充实的一天,

    2022年3月1日
    37
  • 简单易懂的自动编码器

    简单易懂的自动编码器作者:叶虎编辑:田旭引言自动编码器是一种无监督的神经网络模型,它可以学习到输入数据的隐含特征,这称为编码(coding),同时用学习到的新特征可以重构出原始输入数据,称之为解码(decoding)。从直观上来看,自动编码器可以用于特征降维,类似主成分分析PCA,但是其相比PCA其性能更强,这是由于神经网络模型可以提取更有效的新特征。除了进行特征降维,

    2022年5月7日
    52
  • code blocks使用方法总结「建议收藏」

    code blocks使用方法总结「建议收藏」下载和安装:官网地址:http://www.codeblocks.org/downloadstips:同一个版本有多个安装文件,官网上有对于各个文件的简要介绍。最好选择 mingw-se

    2022年8月4日
    3
  • Android 高仿微信即时聊天 百度云为基础的推

    Android 高仿微信即时聊天 百度云为基础的推

    2022年1月15日
    163
  • Expand命令_copy命令的用法

    Expand命令_copy命令的用法使用Expand命令行可以在计算机没有安装Windows操作系统的情况下应用批处理文件和脚本:虽然有多个基于Windows的工具可以压缩和解压缩文件(包括WinZip和WinRAR),但是必须有一个可以工作的Windows操作系统才能使用它们。Expand工具用来压缩的WndowsCAB文件中展开文件,并把释放出来的文件保存在磁盘的指定目录内。这个工具通常用来从Windows安装

    2025年6月11日
    0
  • Visual C++学习笔记1:一定要注意ANSI和UNICODE差额

    Visual C++学习笔记1:一定要注意ANSI和UNICODE差额

    2022年1月16日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号