【JavaScript 算法】双指针法:高效处理数组问题


🔥 个人主页:空白诗

文章目录

双指针法(Two Pointer Technique)是一种高效解决数组和字符串问题的算法技巧,通过维护两个指针来遍历数组,从而在特定条件下高效地解决问题。双指针法通常用于有序数组或字符串,常见的应用场景包括寻找和为特定值的两数、移除元素、合并两个有序数组等。本文将详细介绍双指针法的原理、实现及其应用。


一、算法原理

双指针法通过同时维护两个指针来遍历数组,从而在特定条件下高效地解决问题。双指针法的基本思想是:

  1. 初始化两个指针,通常分别指向数组的起始位置和结束位置,或者都指向起始位置。
  2. 根据特定的条件移动指针,直到满足问题的要求。

二、算法实现

示例问题1:两数之和 II - 输入有序数组

给定一个已按升序排列的数组,找到两个数使得它们的和等于目标数。

javascript 复制代码
/**
 * 在有序数组中找到两个数使得它们的和等于目标数
 * @param {number[]} numbers - 输入的有序数组
 * @param {number} target - 目标和
 * @return {number[]} - 两个数的索引(从1开始计数)
 */
function twoSum(numbers, target) {
  let left = 0;
  let right = numbers.length - 1;

  while (left < right) {
    const sum = numbers[left] + numbers[right];
    if (sum === target) {
      return [left + 1, right + 1]; // 返回结果,索引从1开始计数
    } else if (sum < target) {
      left++; // 移动左指针
    } else {
      right--; // 移动右指针
    }
  }

  return []; // 如果没有找到符合条件的数,返回空数组
}

// 示例
const numbers = [2, 7, 11, 15];
const target = 9;
console.log(twoSum(numbers, target)); // 输出: [1, 2]

示例问题2:反转字符串中的元音字母

编写一个函数,以字符数组为输入,反转该字符串中的元音字母。

javascript 复制代码
/**
 * 反转字符串中的元音字母
 * @param {string} s - 输入字符串
 * @return {string} - 反转元音字母后的字符串
 */
function reverseVowels(s) {
  const vowels = new Set(['a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U']);
  const arr = s.split('');
  let left = 0;
  let right = arr.length - 1;

  while (left < right) {
    while (left < right && !vowels.has(arr[left])) {
      left++;
    }
    while (left < right && !vowels.has(arr[right])) {
      right--;
    }
    if (left < right) {
      [arr[left], arr[right]] = [arr[right], arr[left]];
      left++;
      right--;
    }
  }

  return arr.join('');
}

// 示例
const s = "hello";
console.log(reverseVowels(s)); // 输出: "holle"

注释说明:

  1. 两数之和 II - 输入有序数组

    • let left = 0; let right = numbers.length - 1;:初始化两个指针,分别指向数组的起始位置和结束位置。
    • while (left < right):遍历数组,直到两个指针相遇。
    • const sum = numbers[left] + numbers[right];:计算两个指针指向的数的和。
    • if (sum === target):如果和等于目标数,返回两个数的索引。
    • else if (sum < target):如果和小于目标数,移动左指针。
    • else:如果和大于目标数,移动右指针。
  2. 反转字符串中的元音字母

    • const vowels = new Set(['a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U']);:定义元音字母集合。
    • const arr = s.split('');:将字符串转换为字符数组。
    • let left = 0; let right = arr.length - 1;:初始化两个指针,分别指向数组的起始位置和结束位置。
    • while (left < right && !vowels.has(arr[left])) left++;:移动左指针,直到指向元音字母。
    • while (left < right && !vowels.has(arr[right])) right--;:移动右指针,直到指向元音字母。
    • if (left < right) [arr[left], arr[right]] = [arr[right], arr[left]]; left++; right--;:交换两个元音字母,并移动指针。

三、应用场景

  1. 数组问题:如两数之和、三数之和、移除元素、合并两个有序数组等。
  2. 字符串问题:如反转字符串中的元音字母、最长回文子串等。
  3. 链表问题:如合并两个有序链表、删除链表中的节点等。

四、总结

双指针法是一种高效解决数组和字符串问题的算法技巧,通过同时维护两个指针来遍历数组,可以在特定条件下高效地解决问题。理解和掌握双指针法,可以有效解决许多实际问题,如两数之和、反转字符串中的元音字母等。


相关推荐
xvmingjiang8 分钟前
Vue 3 中监听多个数据变化的几种方法
前端·javascript·vue.js
我有一只臭臭9 分钟前
ES5 和 ES6 类的实现
前端·javascript·es6
2401_8454174512 分钟前
set和map
java·开发语言
2301_8210465224 分钟前
Python的深度学习
开发语言·javascript·ecmascript
爱编程的化学家30 分钟前
代码随想录算法训练营第十一天--二叉树2 || 226.翻转二叉树 / 101.对称二叉树 / 104.二叉树的最大深度 / 111.二叉树的最小深度
数据结构·c++·算法·leetcode·二叉树·代码随想录
tqs_1234530 分钟前
redis zset 处理大规模数据分页
java·算法·哈希算法
小高00734 分钟前
🤔函数柯里化:化繁为简的艺术与实践
前端·javascript·面试
却尘37 分钟前
React useMemo 依赖陷阱:组件重挂载,状态无限复原
前端·javascript·react.js
Asort41 分钟前
JavaScript 从零开始(三):浏览器控制台与VS Code协同工作环境搭建详解
前端·javascript
葡萄城技术团队1 小时前
浏览器为啥要对 JavaScript 定时器“踩刹车”?
javascript