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)
上一篇 2022年6月2日 上午7:46
下一篇 2022年6月2日 上午8:00


相关推荐

  • Poetry(1)Poetry介绍与安装

    Poetry(1)Poetry介绍与安装介绍Poetry是Python中的依赖管理和打包工具,当然它也可以配置虚拟环境。它允许您声明项目所依赖的库,并为您管理(安装/更新)它们。之前一直使用virtualenvwrapper管理虚拟

    2022年7月29日
    29
  • 2026年最新的 Claude 国内使用指南(支持Claude 4、Claude 4.5)

    2026年最新的 Claude 国内使用指南(支持Claude 4、Claude 4.5)

    2026年3月15日
    2
  • JAVA API中文在线帮助文档

    JAVA API中文在线帮助文档https://www.w3cschool.cn/java/dicthttp://www.matools.com/api/java8http://tool.oschina.net/apidocs/apihttp://www.javaweb.cc/help/JavaAPI1.6/overview-summary.html

    2022年7月26日
    33
  • AI假新闻满天飞,打假神器GROVER帮你看清一切

    AI假新闻满天飞,打假神器GROVER帮你看清一切最近 AI 换脸术与 AI 假新闻叠加在一起 造成了不少乌龙事件 比如最近美国的议长南希 佩洛西就的一段醉酒视频就在 Facebook 上流传甚广 视频中的议长明显是状态晕沉 醉意十足 不过这后来被证明是一段是由 deepfake 生成的假视频 后来 Facebook 创始人马克 扎克伯格的一段视频也开始疯传 在其中小扎说 让我们快速地想象一下 一个人手握偷窃来的数十亿人的隐私信息

    2026年3月16日
    4
  • 导航栏跳转页面[通俗易懂]

    导航栏跳转页面[通俗易懂]一个页面有多个导航栏跳转页面一定要有这三步html结构部分<el-menu:default-active=”path”class=”el-menu-vertical-demo”:unique-opened=”true”@select=”listChange”><el-menu-itemindex=”/index/aiIdentify/achievementWall”>

    2022年5月30日
    53
  • 常见大数据框架

    常见大数据框架文件存储 HadoopHDFS Tachyon KFS 离线计算 HadoopMapRed Spark 流式 实时计算 Storm SparkStreami S4 HeronK V NOSQL 数据库 HBase Redis MongoDB 资源管理 YARN Mesos 日志收集 Flume Scribe Logstash Kibana 消息系统 Kafka StormMQ ZeroMQ R

    2026年3月18日
    3

发表回复

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

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