将数组倒序,不能采用reverse,算法复杂度最低

双指针法的工作原理:

  1. 初始化两个指针:left指向数组开头(索引0),right指向数组末尾(索引length-1)

  2. left < right时,交换两个指针指向的元素

  3. left指针向右移动(left++),right指针向左移动(right--)

  4. 重复步骤2-3,直到两个指针相遇或交错

时间复杂度分析

  • 时间复杂度:O(n) - 只需要遍历数组的一半长度(n/2次交换)

  • 空间复杂度:O(1) - 原地修改,不需要额外存储空间

这种方法在时间复杂度上已经是最优解,因为必须访问每个元素至少一次才能完成倒序。空间复杂度也是最优的O(1)

复制代码
const array = Array.from({ length: 100 }, (_, i) => i + 1);
console.log("array", array);

function reverseArrayLike(arr) {
  const result = Array.from(arr);
  let left = 0;
  let right = result.length - 1;

  while (left < right) {
    [result[left], result[right]] = [result[right], result[left]];
    left++;
    right--;
  }

  console.log("result", result);

  return result;
}

reverseArrayLike(array);

1

相关推荐
学涯乐码堂主1 小时前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
Tutankaaa2 小时前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang0073212 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
aini_lovee4 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong99904 小时前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语5054 小时前
深入理解主成分分析(PCA)
算法
apollowing4 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app
晚枫歌F5 小时前
最小堆定时器
数据结构·算法
Lumos_7775 小时前
Linux -- 线程
java·jvm·算法
七颗糖很甜6 小时前
“十五五”气象发展规划:聚焦五大核心任务
大数据·python·算法