技术文摘
用 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 插入排序 升序排序 数字数组
- 业务驱动下的前端性能有效实践之前端质量
- JS 获取 GIF 总帧数探讨
- 摆脱原型与原型链的迷雾,快清醒
- Python 中快速循环的方式,你知晓多少?
- JDK 中有关监听文件变更的一个 Bug 需留意
- Jmeter 接口测试落地的实现策略
- CSS 自定义无序列表样式的使用方法
- RocketMQ 消息中间件的深度解析
- Java 多线程专题:线程类与接口初探
- JVM 内存架构与 GC 算法基础
- Spring 框架中的 Bean 作用域
- HashMap 面试要点,看这篇文章足矣!
- Spring.Factories 即将弃用,新写法速知
- CIO 助力企业迅速调整以适应市场变化的策略
- 你了解 Github Actions 吗?