Leetcode 1. 两数之和

心路历程:

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

注意的点:

1、题目需要返回原数组的索引,所以排序后还需要对应原数组,还好只要返回唯一解。

2、对应原数组的时候注意处理两个指针赋值不能相同的情况(无法直接用.index())

3、right指针大于left指针即可,总是有时候把左右指针写反。

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

python 复制代码
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]
相关推荐
想跑步的小弱鸡5 小时前
Leetcode hot 100(day 3)
算法·leetcode·职场和发展
xyliiiiiL6 小时前
ZGC初步了解
java·jvm·算法
爱的叹息7 小时前
RedisTemplate 的 6 个可配置序列化器属性对比
算法·哈希算法
独好紫罗兰7 小时前
洛谷题单2-P5713 【深基3.例5】洛谷团队系统-python-流程图重构
开发语言·python·算法
每次的天空8 小时前
Android学习总结之算法篇四(字符串)
android·学习·算法
请来次降维打击!!!9 小时前
优选算法系列(5.位运算)
java·前端·c++·算法
qystca9 小时前
蓝桥云客 刷题统计
算法·模拟
别NULL9 小时前
机试题——统计最少媒体包发送源个数
c++·算法·媒体
weisian1519 小时前
Java常用工具算法-3--加密算法2--非对称加密算法(RSA常用,ECC,DSA)
java·开发语言·算法
程序员黄同学11 小时前
贪心算法,其优缺点是什么?
算法·贪心算法