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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 员工管理系统源码_小公司服务器方案

    员工管理系统源码_小公司服务器方案简介:员工管理系统源码是一款:基于ThinkPHP框架开发的员工管理/员工信息记录系统,有增删改查功能,源码全开源,方便二次开发,搭建和使用都很简单安装教程:环境:Linux+mysql5.6+php7.2安装步骤:1.新建站点–》上传–》解压2.导入数据库文件3.修改/数据库 \Application\Home\Conf\config.php4.后台地址/home/login/index账号密码admin  www.ohbbs.cn5

    2022年9月23日
    1
  • jetbrains系列软件汉化图文教程

    idea 激活码,jetbrains系列软件汉化图文教程

    2022年3月13日
    63
  • 卡尔曼滤波(KF)与扩展卡尔曼滤波(EKF)的一种理解思路及相应推导(1)

    卡尔曼滤波(KF)与扩展卡尔曼滤波(EKF)的一种理解思路及相应推导(1)前言:从上个世纪卡尔曼滤波理论被提出,卡尔曼滤波在控制论与信息论的连接上做出了卓越的贡献。为了得出准确的下一时刻状态真值,我们常常使用卡尔曼滤波、扩展卡尔曼滤波、无迹卡尔曼滤波、粒子滤波等等方法,这些方法在姿态解算、轨迹规划等方面有着很多用途。卡尔曼滤波的本质是参数化的贝叶斯模型,通过对下一时刻系统的初步状态估计(即状态的先验估计)以及测量得出的反馈相结合,最终得到下一时刻较为准确的的状态估计

    2022年6月28日
    48
  • Wireshark安装后打开显示没有找到接口

    我遇到这个问题是出现在Win10系统中,出现这个问题的原因是Wireshark中由于自带的Winpcap不支持Win10。出现如图所示:1.这个问题的解决方法是下载一个Win10支持的Winpcap,下载链接为点击打开链接,界面如图:点击红色区域下载即可。注意:下载下来的红色区域即可。注意:下载下来Win10Pcap后,在安装前先将Wireshark关掉,要不然安装过程中会报错。2.安装完成后,重…

    2022年4月7日
    351
  • Ubuntu安装nginx_服务器安装Ubuntu

    Ubuntu安装nginx_服务器安装Ubuntu版本ubunt16.04nginx-1.8.1gcc-4.8.4pcre-8.38zlib-1.2.11openssl-1.0.2n前置环境配置进入到/usr/local目录下执行下面1234,此处路劲与之后安装nginx对应,需要注意*1、gcc源码编译依赖环境apt-getinstallbuild-essentialapt-

    2022年9月18日
    1

发表回复

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

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