「程序员必须掌握的算法」双指针「上篇」

双指针(Two Pointers)是解决算法问题的常用方法之一,它通过维护两个指针在某个序列中游走来解决问题。最常见的双指针问题是在一个有序数组中查找是否存在两个数的和等于目标值。

具体来说,设一个指针 left 初始指向数组第一个元素,一个指针 right 初始指向数组最后一个元素。然后,我们每次将它们的和与目标值比较:

  • 如果两数之和等于目标值,则直接返回结果;
  • 如果两数之和小于目标值,则将 left 指针右移一位;
  • 如果两数之和大于目标值,则将 right 指针左移一位。

这样不断移动指针,直到找到目标值或者 left >= right。下面是一个示例代码:

java 复制代码
public boolean twoSum(int[] nums, int target) {
    int left = 0, right = nums.length - 1;
    while (left < right) {
        int sum = nums[left] + nums[right];
        if (sum == target) {
            return true;
        } else if (sum < target) {
            left++;
        } else {
            right--;
        }
    }
    return false;
}

值得注意的是,这里假定数组中的元素是有序的。如果没有排序,我们可以先排序,然后再使用双指针解决问题。当然,也有一些问题不需要排序就可以使用双指针,比如反转字符串、链表等。

另外,维护两个指针的算法并不仅限于两数之和问题。比如在一个字符串中查找最长回文子串,我们可以使用两个指针不断扩展,判断当前子串是否为回文。这个问题的具体解法可以参考我的博客「最长回文子串」。

总之,双指针是一种简单而有效的解决算法问题的方法,程序员在日常开发中必须掌握。

相关推荐
朝朝又沐沐38 分钟前
算法竞赛阶段二-数据结构(40)数据结构栈的STL
开发语言·数据结构·c++·算法
2501_9277730738 分钟前
数据结构——单向链表
数据结构·算法
程序猫.1 小时前
C语言 二分查找:高效搜索有序数组
c语言·算法
weisian1511 小时前
力扣经典算法篇-38-组合(回溯算法)
算法·leetcode·职场和发展
努力写代码的熊大2 小时前
八大排序算法
java·算法·排序算法
xiaobaibai1532 小时前
智慧交通中目标检测 mAP↑28%:陌讯多模态融合算法实战解析
人工智能·算法·目标检测·计算机视觉·目标跟踪·视觉检测
战争热诚2 小时前
基于transformer的目标检测——匈牙利匹配算法
算法·目标检测·transformer
计算机科研圈3 小时前
ICCV 2025 | EPD-Solver:西湖大学发布并行加速扩散采样算法
人工智能·算法·语言模型·自然语言处理·数据挖掘·iccv
闪电麦坤953 小时前
数据结构:在链表中插入节点(Inserting in a Linked List)
数据结构·链表