[算法][力扣167]Two Sum II

给定一个有序整型数组和一个整数target,在其中寻找两个元素,使其和为target。返回这两个数的索引。

  • 如numbers = 2, 7, 11, 15, target = 9
  • 返回数字2, 7的索引1, 2 (索引从1开始计算)

思路一:使用暴力解法,两重for循环

思路二:对撞指针,即用两个指针,left = 0, right = length - 1从两边出发

target和两个指针的和(sum)对比,分三种情况

1、如果 sum == target,则成功找到目标数据

2、如果 sum > target,则right --

3、如果 sum < target,则left++

java 复制代码
public class Test02_167_001 {

    public static void main(String[] args) {
        int[] ret = twoSum(new int[]{2, 7, 11, 15}, 29);
        System.out.println(Arrays.toString(ret));
    }

    public static int[] twoSum(int[] arr, int target) {
        int left = 0;
        int right = arr.length - 1;
        while (left < right) {
            int sum = arr[left] + arr[right];
            if (sum == target) {
                return new int[]{left, right};
            } else if (sum < target) {
                left++;
            } else { // sum > target
                right--;
            }
        }
        return new int[]{};
    }
}
相关推荐
凯瑟琳.奥古斯特12 小时前
力扣1003题C++解法详解
开发语言·c++·算法·leetcode·职场和发展
计算机安禾12 小时前
【算法分析与设计】第48篇:流算法与数据概要技术
java·服务器·网络·数据库·算法
hunterkkk(c++)12 小时前
SPFA最短路径算法(c++)
java·c++·算法
大学竞赛君12 小时前
第十六届蓝桥杯大赛软件赛决赛 Python 大学 A 组
python·职场和发展·蓝桥杯
weixin_4462608512 小时前
HANDOFF:基于蒸馏互补教师的人形机器人任务空间整体控制
人工智能·算法·机器人
luweis12 小时前
企智孪生 ETA (6.3 数字人格 (Digital Persona) 的构建工程、6.4 交互触点:全场景嵌入策略)【杭州联保致新科技有限公司 卢伟舜】
人工智能·程序人生·机器学习·自然语言处理·职场和发展·知识图谱·学习方法
商业模式源码开发12 小时前
知识付费推三返一模式详解:规则设计、分红算法与合规架构
算法·架构·推三返一
fengfuyao98512 小时前
基于MATLAB的HHT变换完整实现(含EMD分解与三维时频谱生成)
开发语言·算法·matlab
剑挑星河月12 小时前
98.验证二叉搜索树
java·算法·leetcode
罗超驿12 小时前
16.滑动窗口经典例题:最小覆盖子串(LeetCode 76)算法原理剖析
算法·leetcode·职场和发展