leetcode167:两数之和|| - 输入有序数组

题目链接:167. 两数之和 II - 输入有序数组 - 力扣(LeetCode)

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

这个题目,其实有两复杂度的算法,一个是nlogn 一个是n 我这个代码复杂度是n

为什么这道题要用复杂度为n呢,其实我们分析一下nlogn和n谁大,这个是要分区间来讨论的,首先当n < 10的时候,nlogn肯定小于n, 当n = 10的时候,两个相等,当n大于10的时候,这时候nlogn是大于n的,所以来看,我们这道题实际上用复杂度n会更好

代码讲解:这个题目实际上就是和双指针的结合,这个代码为什么我要用 numbers[right] > target - numbers[left]而不是用numbers[right] + numbers[right] > target,这个问题也就好比我们用二分的时候,用left + (right - left) / 2 而不是用(left + right)/ 2这个道理是一样的,为了防止加法超出int范围

这个代码就是把left定在数组的最左边,right定在数组的最后边,然后去寻找,当numbers[left] + numbers[right] > target 的时候,这个时候肯定是让right--,因为你想想,你要是right++,那必定是大于target的,同理numbers[left] + numbers[right] < target的道理一样。

相关推荐
ysa0510304 分钟前
虚拟位置映射(标签鸽
数据结构·c++·笔记·算法
程序员小远8 分钟前
快速定位bug,编写测试用例
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·bug
Yue丶越9 分钟前
【C语言】深入理解指针(二)
c语言·开发语言·数据结构·算法·排序算法
m0_7482480213 分钟前
C++中的位运算符:与、或、异或详解
java·c++·算法
沐浴露z15 分钟前
详解【限流算法】:令牌桶、漏桶、计算器算法及Java实现
java·算法·限流算法
网安墨雨30 分钟前
外包干了两年,我走出了安乐窝。。。
自动化测试·软件测试·职场和发展·压力测试
王哈哈^_^37 分钟前
【完整源码+数据集】草莓数据集,yolov8草莓成熟度检测数据集 3207 张,草莓成熟度数据集,目标检测草莓识别算法系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
油泼辣子多加1 小时前
【实战】自然语言处理--长文本分类(3)HAN算法
算法·自然语言处理·分类
Shinom1ya_1 小时前
算法 day 46
数据结构·算法
夏鹏今天学习了吗2 小时前
【LeetCode热题100(64/100)】搜索旋转排序数组
算法·leetcode·职场和发展