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

相关推荐
m0_377618235 小时前
Golang怎么连接MySQL数据库_Golang MySQL连接教程【总结】
jvm·数据库·python
LN花开富贵5 小时前
【ROS】鱼香ROS2学习笔记一
linux·笔记·python·学习·嵌入式·ros·agv
weixin_586061466 小时前
C#怎么通过反射获取类属性_C#如何动态读取元数据【进阶】
jvm·数据库·python
Jurio.6 小时前
本机开发 + 多机执行的极简远端运行工具
linux·git·python·github·远程工作
HoneyMoose6 小时前
Jenkins Cloudflare 部署提示错误
java·servlet·jenkins
阿丰资源6 小时前
基于SpringBoot的物流信息管理系统设计与实现(附资料)
java·spring boot·后端
skywalk81636 小时前
pytest测试的时候这是什么意思?Migrating <class ‘kotti.resources.File‘>
前端·python
Predestination王瀞潞6 小时前
Java EE3-我独自整合(第四章:Spring bean标签的常见配置)
java·spring·java-ee
overmind6 小时前
oeasy Python 121[专业选修]列表_多维列表运算_列表相加_列表相乘
java·windows·python
资深数据库专家6 小时前
总账EBS 应用服务器1 的监控分析
java·网络·数据库