技术文摘
用 JavaScript 实现插入排序对数字数组升序排序
用 JavaScript 实现插入排序对数字数组升序排序
在编程领域,排序算法是一项基础且至关重要的技能。插入排序作为一种简单直观的排序算法,特别适合于数据量较小或者部分有序的数据集合。本文将详细介绍如何使用 JavaScript 实现插入排序对数字数组进行升序排序。
插入排序的基本思想是将数组分为已排序和未排序两部分。初始时,已排序部分仅包含数组的第一个元素,其余部分为未排序部分。接着,从未排序部分选取元素,将其插入到已排序部分的合适位置,直到整个数组都被排序。
下面是用 JavaScript 实现插入排序的代码:
function insertionSort(arr) {
const n = arr.length;
for (let i = 1; i < n; i++) {
let key = arr[i];
let j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
return arr;
}
在这段代码中,外层循环从数组的第二个元素开始,每次迭代处理一个未排序的元素。内层循环则在已排序的元素中寻找合适的插入位置。如果当前已排序元素大于要插入的元素,就将该元素后移一位,为插入元素腾出空间。当找到合适位置或者内层循环结束时,将待插入元素插入到正确的位置。
使用时,只需调用这个函数并传入需要排序的数字数组即可。例如:
let numbers = [5, 3, 8, 2, 9, 1];
let sortedNumbers = insertionSort(numbers);
console.log(sortedNumbers);
这段代码定义了一个包含多个数字的数组,调用插入排序函数后,输出排序后的数组。
插入排序的时间复杂度在最坏情况下为 O(n²),最好情况下为 O(n),空间复杂度为 O(1)。虽然它的效率不如一些高级排序算法,但因其简单易懂、代码实现简洁,在某些特定场景下仍然非常实用。通过掌握插入排序,开发者可以更好地理解排序算法的基本原理,并为学习更复杂的算法打下坚实基础。
TAGS: JavaScript 插入排序 升序排序 数字数组
- 箭头函数:方便快捷但需留意陷阱
- Java 实现 Excel 行和列的删除
- 一位 46 岁程序员的面试让我思绪纷飞
- 9 个实用的网络调试命令,你掌握了多少?
- 因搞不定 0.2 这样简单的数字,你被炒了,笨蛋!
- 软件工程师就业新走向:10 年以上经验面试机会减少,VR/AR 需求猛增 14 倍
- 这些被低估却好用的 Python 库,你了解多少?
- 五分钟搞定一个小小爬虫
- 分布式系统中的时间难题
- CODING:连小白都能上手的代码协作工具
- Rust 构建微服务的方法探讨
- 码云企业版管理软件的软件研发全流程运用之道
- 借助 GitHub 企业版搭建企业内部开源平台
- 华为软件开发云(DevCloud)的发展历程
- Android Context 各类未知细节的全面剖析