前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 1. 两数之和 Two Sum「建议收藏」

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

作者头像
全栈程序员站长
发布2022-09-05 10:40:31
1770
发布2022-09-05 10:40:31
举报
文章被收录于专栏:全栈程序员必看

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

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

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

示例:

给定 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 个元素。
代码语言:javascript
复制
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「建议收藏」
LeetCode 1. 两数之和 Two Sum「建议收藏」

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年6月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档