JavaScript 数组排序实战指南:从基础到高级的全面解析

JavaScript 数组排序是前端开发中的核心技能之一,广泛应用于数据可视化、列表展示、搜索结果排序等场景。本文将从基础排序方法入手,深入探讨各种排序算法的实现原理、性能特点及实战技巧,并结合具体案例展示如何应对复杂排序需求。

一、JavaScript 数组排序基础

1.1 数组排序的基本概念
  • 排序定义:将数组元素按特定顺序(升序或降序)重新排列。
  • 原地排序:直接修改原数组,不创建新数组。
  • 稳定排序:相等元素的相对顺序在排序后保持不变。
1.2 内置排序方法:Array.prototype.sort()
// 基本用法(默认按字符串 Unicode 码点排序)
const numbers = [10, 5, 8, 1, 7];
numbers.sort(); // [1, 10, 5, 7, 8]

// 自定义比较函数(升序)
numbers.sort((a, b) => a - b); // [1, 5, 7, 8, 10]

// 降序排序
numbers.sort((a, b) => b - a); // [10, 8, 7, 5, 1]

// 字符串排序(忽略大小写)
const strings = ['banana', 'Apple', 'cherry'];
strings.sort((a, b) => a.localeCompare(b, 'en', {
   
    sensitivity: 'base' }));
// ['Apple', 'banana', 'cherry']
1.3 比较函数的工作原理
  • 返回值小于 0a 排在 b 前面。
  • 返回值等于 0ab 的顺序不变。
  • 返回值大于 0b 排在 a 前面。

二、常见排序算法及其实现

2.1 冒泡排序(Bubble Sort)
/**
 * 冒泡排序实现
 * @param {Array} arr - 待排序数组
 * @returns {Array} - 排序后的数组
 */
function bubbleSort(arr) {
   
   
  const len = arr.length;
  for (let i = 0; i < len - 1; i++) {
   
   
    for (let j = 0; j < len - 1 - i; j++) {
   
   
      if (arr[j] > arr[j + 1]) {
   
   
        // 交换元素
        [arr[j], arr[j + 1]] = [arr[j + 1], arr[j]];
      }
    }
  }
  return arr;
}

// 使用示例
const unsortedArray = [5, 3, 8, 4, 2];
console.log(bubbleSort([...unsortedArray])); // [2, 3, 4, 5, 8]
2.2 选择排序(Selection Sort)
/**
 * 选择排序实现
 * @param {Array} arr - 待排序数组
 * @returns {Array} - 排序后的数组
 */
function selectionSort(arr) {
   
   
  const len = arr.length;
  for (let i = 0; i < len - 1; i++) {
   
   
    let minIndex = i;
    for (let j = i + 1; j < len; j++) {
   
   
      if (arr[j] < arr[minIndex]) {
   
   
        minIndex = j;
      }
    }
    if (minIndex !== i) {
   
   
      [arr[i], arr[minIndex]] = [arr[minIndex], arr[i]];
    }
  }
  return arr;
}

// 使用示例
console.log(selectionSort([...unsortedArray])); // [2, 3, 4, 5, 8]
2.3 插入排序(Insertion Sort)
/**
 * 插入排序实现
 * @param {Array} arr - 待排序数组
 * @returns {Array} - 排序后的数组
 */
function insertionSort(arr) {
   
   
  const len = arr.length;
  for (let i = 1; i < len; i++) {
   
   
    const current = arr[i];
    let j = i - 1;
    while (j >= 0 && arr[j] > current) {
   
   
      arr[j + 1] = arr[j];
      j--;
    }
    arr[j + 1] = current;
  }
  return arr;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

读心悦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值