Leetcode 1. 两数之和

在这里插入图片描述

心路历程:

很简单的题,双层暴力就可以,用双指针的话快一点。暴力时间复杂度O( n 2 n^2 n2),双指针时间复杂度O(nlogn) + O(n) + O(n) = O(nlogn)。

注意的点:

1、题目需要返回原数组的索引,所以排序后还需要对应原数组,还好只要返回唯一解。
2、对应原数组的时候注意处理两个指针赋值不能相同的情况(无法直接用.index())
3、right指针大于left指针即可,总是有时候把左右指针写反。

解法:排序、双指针、返回对应原数组索引

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        # 双指针
        newnums = sorted(nums)
        left = 0
        right = len(nums) - 1
        while right > left: 
            if newnums[left] + newnums[right] == target:
                break
            elif newnums[left] + newnums[right] > target:
                right -= 1
            else:
                left += 1
        assert left != right
        
        l1, l2 = 0, 0
        flag = False
        for i in range(len(nums)):
            if newnums[left] == nums[i] and not flag:
                l1 = i
                flag = True
            elif newnums[right] == nums[i]:
                l2 = i
        return [l1, l2]

相关推荐

  1. LeetCode 1. 之和

    2024-03-18 20:28:01       58 阅读
  2. leetcode 1之和

    2024-03-18 20:28:01       33 阅读
  3. LeetCode1之和

    2024-03-18 20:28:01       18 阅读
  4. Leetcode 1.之和

    2024-03-18 20:28:01       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-18 20:28:01       17 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-18 20:28:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-18 20:28:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-18 20:28:01       18 阅读

热门阅读

  1. PHP过滤Emoji表情和特殊符号的方法

    2024-03-18 20:28:01       15 阅读
  2. 基于docker commit和Dockerfile为镜像添加ssh服务

    2024-03-18 20:28:01       20 阅读
  3. 蚓链与数字化供应链的融合 带给新零售新福音

    2024-03-18 20:28:01       20 阅读
  4. C语言经典面试题目(十一)

    2024-03-18 20:28:01       19 阅读
  5. 什么是web workers?使用场景?

    2024-03-18 20:28:01       15 阅读
  6. Android 8.1 实体键盘输入时收起软键盘

    2024-03-18 20:28:01       18 阅读
  7. 关于安卓文件夹压缩和解压(一)zip处理

    2024-03-18 20:28:01       18 阅读
  8. LeetCode--151

    2024-03-18 20:28:01       20 阅读