[Java][Leetcode middle] 167. 两数之和 II - 输入有序数组

官解1:由于输入数组是有序的,因此考虑二分查找

依次循环i,在i之后的元素中寻找j,如果可以找到就返回,找不到继续循环。

java 复制代码
class Solution {
    public int[] twoSum(int[] numbers, int target) {
       int len = numbers.length;
       for(int i=0;i<len;i++){
          int j = target - numbers[i];
          int left = i+1;
          int right = len - 1;
          while(left <= right){
              int mid = left + (right - left)/2;
              if(numbers[mid] == j){
                return new int[]{i+1, mid+1};
              }else if(numbers[mid] < j){
                 left = mid + 1;
              }else{
                 right = mid - 1;
              }
          }
       }
       return new int[]{-1,-1};
    }
}

管解2: 官解

使用左右两个指针

  • 当两数之和等于目标是,说明找到了,返回
  • 当大于目标时,说明大了,使较大的数(右侧的数)-1
  • 当小于目标时,说明小了,使较小的数(左侧的数)+1
java 复制代码
class Solution {
    public int[] twoSum(int[] numbers, int target) {
       int start = 0;
       int end = numbers.length -1;

       while(start < end){
           if(numbers[start] + numbers[end] == target){
              return new int[]{start+1, end+1};
           }else if(numbers[start] + numbers[end] > target){
              end--;
           }else{
              start++;
           }
       }
       return new int[]{-1,-1};
    }
   
}
相关推荐
CN-Dust1 小时前
【C++】输入cin例题专题
java·c++·算法
数模竞赛Paid answer2 小时前
2025年MathorCup数学建模A题汽车风阻预测解题文档与程序
算法·数学建模·mathorcup
xin_nai2 小时前
LeetCode热题100(Java)(6)矩阵
java·leetcode·矩阵
代码AI弗森7 小时前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
Old Uncle Tom8 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆8 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
小小小米粒8 小时前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
生信碱移8 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业8 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机