将数组倒序,不能采用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

相关推荐
IDIOT___IDIOT4 小时前
KNN and K-means 监督与非监督学习
学习·算法·kmeans
Hcoco_me4 小时前
大模型面试题18:t-SNE算法详解及入门实操
算法
Data_agent5 小时前
学术爬虫实战:构建知网论文关键词共现网络的技术指南
python·算法
立志成为大牛的小牛5 小时前
数据结构——五十五、散列查找的性能分析(线性探测法)(王道408)
数据结构·程序人生·考研·算法
神也佑我橙橙6 小时前
Thrift 简单介绍
算法
simon_skywalker6 小时前
线性代数及其应用习题答案(中文版)第二章 矩阵代数 2.1 矩阵运算(2)
线性代数·算法·矩阵
断剑zou天涯7 小时前
【算法笔记】Manacher算法
java·笔记·算法
monster000w7 小时前
大模型微调过程
人工智能·深度学习·算法·计算机视觉·信息与通信