力扣题库第一题:两数之和

两数之和

题目描述

text 复制代码
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target  的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。

你可以按任意顺序返回答案。

示例 1:

输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。
示例 2:

输入:nums = [3,2,4], target = 6
输出:[1,2]
示例 3:

输入:nums = [3,3], target = 6
输出:[0,1]

提示:

2 <= nums.length <= 104
-109 <= nums[i] <= 109
-109 <= target <= 109
只会存在一个有效答案

进阶:你可以想出一个时间复杂度小于 O(n2) 的算法吗?

解题方法

暴力方法 - 循环遍历 - 时间复杂度O(n2)

  1. 思路

    这种方法比较简单,就是通过两层循环进行解题,在外层循环中,我们首先用target的值减去当前的元素,再在里层循环中找出和这个差值相等的元素,得到两个偏移即可。注意在循环的过程中(Python语言)要使用偏移,而不是直接循环元素值。

  2. 代码

python 复制代码
class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        for i in range(len(nums)):
            minus = target - nums[i]
            for j in range(i+1, len(nums)):
                if nums[j] == minus:
                    return [i, j]

使用哈希表 - 时间复杂度O(n)

  1. 思路

    我们将key的值存储为nums数组中的每一个元素,将key对应的value存储为元素对应的索引,这样在便利整个nums数组的时候,如果target - 当前的元素在哈希表中 ,那么说明已经找到了符合题意的两个数,将偏移返回即可,如果target - 当前的元素不在哈希表中,则说明还没有找到符合题意的两个数,这时候将值和索引存入哈希表。即{值: 偏移},这样我们既可以快速地找到满足题意的数,还能方便地找到数对应的偏移,一举两得。

  2. 代码

python 复制代码
class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        map = {}
        for offset, num in enumerate(nums):
            if target - num in map:
                return [offset, map[target - num]]
            else:
                map[num] = offset

总结

当我们做题的时候,可以先考虑使用最简单的暴力解法进行解题,然后可以思考使用高时间效率的方法,如果实在没有思路可以查看大佬的解法,这样有利于提高自己的编程能力。拜拜~

相关推荐
灵犀海棠16 分钟前
通过Anaconda Prompt激活某个虚拟环境并安装第三方库
python
cainiao08060522 分钟前
Neuralink API开发指南:用Python读取脑电信号控制智能家居
开发语言·python·智能家居
独好紫罗兰27 分钟前
洛谷题单2-P2433 【深基1-2】小学数学 N 合一-python-流程图重构
开发语言·python·算法
独好紫罗兰28 分钟前
洛谷题单2-P5709 【深基2.习6】Apples Prologue 苹果和虫子-python-流程图重构
开发语言·python·算法
MobiCetus35 分钟前
【MachineLearning】生成对抗网络 (GAN)
linux·人工智能·python·深度学习·神经网络·生成对抗网络·机器人
安然无虞41 分钟前
31天Python入门——第18天:面向对象三大特性·封装继承多态
开发语言·后端·爬虫·python
多多*1 小时前
JVM Java类加载 isInstance instanceof 的区别
开发语言·python·spring·ai作画·eclipse·maven
开开心心就好1 小时前
开启智能生活新篇:免费 APP 实现家电万能操控
java·windows·python·微信·pdf·生活·软件需求
啊阿狸不会拉杆2 小时前
第十九章:Python-pyttsx3 库实现文本转语音功能
开发语言·python·语音·pyttsx
独好紫罗兰2 小时前
洛谷题单1-P1001 A+B Problem-python-流程图重构
开发语言·python·算法