技术文摘
JavaScript 中的冒泡排序和选择排序
JavaScript 中的冒泡排序和选择排序
在 JavaScript 编程中,排序算法是非常重要的一部分。冒泡排序和选择排序是两种常见且基础的排序算法。
冒泡排序(Bubble Sort)是一种简单直观的排序算法。它重复地走访要排序的数列,一次比较两个数据元素,如果顺序不对则进行交换,并一直重复这样的走访操作,直到没有要交换的数据元素为止。
以下是冒泡排序的 JavaScript 实现代码:
function bubbleSort(arr) {
let n = arr.length;
for (let i = 0; i < n; i++) {
for (let j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
let temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
选择排序(Selection Sort)则是每次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。
以下是选择排序的 JavaScript 实现代码:
function selectionSort(arr) {
let n = arr.length;
for (let i = 0; i < n - 1; i++) {
let min_idx = i;
for (let j = i + 1; j < n; j++) {
if (arr[j] < arr[min_idx]) {
min_idx = j;
}
}
if (min_idx!= i) {
let temp = arr[i];
arr[i] = arr[min_idx];
arr[min_idx] = temp;
}
}
}
冒泡排序和选择排序都有各自的特点。冒泡排序的优点是实现简单,容易理解,但它的效率相对较低,尤其是在处理大规模数据时。选择排序在性能上相对冒泡排序略有提升,但也不是最优的排序算法。
在实际应用中,对于较小规模的数据,这两种排序算法可能足够满足需求。但对于大规模数据,通常会使用更高效的排序算法,如快速排序、归并排序等。
了解和掌握冒泡排序和选择排序,有助于我们理解排序算法的基本原理和思想,为进一步学习和应用更复杂的算法打下坚实的基础。通过对不同算法的性能比较和分析,我们能够在实际编程中根据具体情况选择最合适的排序方法,以提高程序的效率和性能。
TAGS: JavaScript 数据结构 JavaScript 排序 JavaScript 冒泡排序 JavaScript 选择排序
- 深入解析 JS 闭包:揭秘闭包表达式中两个连续括号的原因
- Tailwind CSS中line-height/leading失效问题及垂直居中实现方法
- JavaScript动态调整SVG元素高度和颜色的方法
- position: sticky失效的原因
- 父容器溢出滚动且子 div 横向排列的实现方法
- 部署包含Vue和HTML项目的混合项目方法
- 使用 TailwindCSS 的 line-height 和 leading 类无法垂直居中文字元素的原因
- 移动端 rem 计算引发页面扭曲变动的解决方法
- 方法链中filter()与map()效率是否低下
- JavaScript中this指向何方
- 父容器横向滚动且子 div 横向排列的实现方法
- HTML元素莫名高出4px,是内联元素行内对齐问题吗
- position: sticky失效原因剖析:sticky元素为何被表格遮挡
- JavaScript 如何动态修改 SVG 进度条的高度与颜色
- Tailwind CSS 中 line-height(leading)失效怎么办?怎样实现元素垂直居中?