167. 两数之和 II - 输入有序数组(中等)

167. 两数之和 II - 输入有序数组

1. 题目描述

题目中转:167. 两数之和 II - 输入有序数组

2.详细题解

作为双指针方法的第一弹,先简要介绍下该方法:

  • 若两个指针指向同一数组,遍历方向相同且不会相交,则也称为滑动窗口(两个指针包围的区域即为当前的窗口),经常用于区间搜索。
  • 若两个指针指向同一数组,但是遍历方向相反,则可以用来进行搜索,待搜索的数组往往是排好序的。
       本题同力扣 1.两数之和类似,唯一区别是该题的整数数组是有序的,先直接上暴力破解方法,双重循环遍历,可以看到,Python直接超时在第19个测试用例即失败,Java虽然测试用例通过,但报错耗时太长.
python 复制代码
class Solution:
    def twoSum(self, numbers: List[int], target: int) -> List[int]:
        for left in range(len(numbers)):
            for right in range(left+1,len(numbers)):
                if numbers[left] + numbers[right] == target:
                    return [left+1, right+1]
java 复制代码
class Solution {
    public int[] twoSum(int[] numbers, int target) {
        for (int i=0;i<numbers.length;i++){
            for (int j=i+1;j<numbers.length;j++){
                if (numbers[i] + numbers[j] == target){
                    return new int[]{i+1, j+1};
                }
            }
        }
        return new int[0];
    }
}

既然该题和 1.两数之和虽然类似,但增加了有序:寻找两个数时,固定第一个数,因此有序,因此第二个数可以直接使用二分查找算法,不用再逐一遍历。进一步的,因为有序,第一个数也可以不用固定,可以使用双指针,两个指针遍历方向相反进而实现搜索,具体描述如下:

一个左指针(left)指向最小的元素,向右遍历;一个右指针(right)指向最大的元素,向左遍历;

如果两个指针指向的元素之和大于目标值,那么将右指针左移动一位,使当前和变小一点;

如果两个指针指向的元素之和小于目标值,那么将左指针右移动一位,使当前和变大一点;

如果两个指针指向的元素之和等于目标值,那么它们就是我们想要的结果;

但需要注意的是,该题的索引是从1开始而不是0开始,因此索引值需要各加1。

3.代码实现

3.1 Python

python 复制代码
class Solution:
    def twoSum(self, numbers: List[int], target: int) -> List[int]:
        left = 0
        right = len(numbers) - 1
        while left < right:
            if numbers[left] + numbers[right] > target:
                right -= 1
            elif numbers[left] + numbers[right] < target:
                left += 1
            else:
                break
        return [left+1, right+1]

3.2 Java

java 复制代码
class Solution {
    public int[] twoSum(int[] numbers, int target) {
        int left = 0;
        int right = numbers.length - 1;
        while (left < right){
            if (numbers[left] + numbers[right] > target){
                right--;
            }else if (numbers[left] + numbers[right] < target){
                left++;
            }else{
                break;
            }
        }
        return new int[]{left+1, right+1};
    }
}

执行用时不必过于纠结,对比可以发现,对于python和java完全相同的编写,java的时间一般是优于python的;至于编写的代码的执行用时击败多少对手,执行用时和网络环境、当前提交代码人数等均有关系,可以尝试完全相同的代码多次执行用时也不是完全相同,只要确保自己代码的算法时间复杂度满足相应要求即可,也可以通过点击分布图查看其它coder的code

相关推荐
2301_80761149几秒前
310. 最小高度树
c++·算法·leetcode·深度优先·回溯
玉笥寻珍4 分钟前
web安全渗透测试基础知识之登录绕过篇
python·安全·web安全·网络安全·威胁分析
@ chen13 分钟前
常见排序算法及其java实现
java·算法·排序算法
Eric.Lee202117 分钟前
conda 输出指定python环境的库 输出为 yaml文件
linux·python·conda
PAQQ22 分钟前
【python】windows实现与k230使用socket通信并传输文件
python·stm32·单片机
胡耀超38 分钟前
图像颜色理论与数据挖掘应用的全景解析
人工智能·python·opencv·计算机视觉·数据挖掘·视觉检测·pillow
带刺的坐椅1 小时前
SpringBoot2 可以使用 SolonMCP 开发 MCP(江湖救急)
java·spring·ai·solon·mcp
love530love1 小时前
家用或办公 Windows 电脑玩人工智能开源项目配备核显的必要性(含 NPU 及显卡类型补充)
人工智能·windows·python·开源·电脑
shengjk11 小时前
序列化和反序列化:从理论到实践的全方位指南
java·大数据·开发语言·人工智能·后端·ai编程
jimsten1 小时前
苍穹外卖 - Day02 学习笔记
java·笔记·学习