TypeScript实现十大排序算法之冒泡排序示例详解

目录
  • 一. 冒泡排序的定义
  • 二. 冒泡排序的流程
  • 三. 冒泡排序的图解
  • 四. 冒泡排序的代码
  • 五. 冒泡排序的时间复杂度
  • 六. 冒泡排序的总结

一. 冒泡排序的定义

冒泡排序是一种简单的排序方法。

  • 基本思路是通过两两比较相邻的元素并交换它们的位置,从而使整个序列按照顺序排列。
  • 该算法一趟排序后,最大值总是会移到数组最后面,那么接下来就不用再考虑这个最大值。
  • 一直重复这样的操作,最终就可以得到排序完成的数组。

这种算法是稳定的,即相等元素的相对位置不会发生变化。

  • 而且在最坏情况下,时间复杂度为O(n^2),在最好情况下,时间复杂度为O(n)。

因此,冒泡排序适用于数据规模小的场景。

二. 冒泡排序的流程

冒泡排序的流程如下:

  • 从第一个元素开始,逐一比较相邻元素的大小。
  • 如果前一个元素比后一个元素大,则交换位置。
  • 在第一轮比较结束后,最大的元素被移动到了最后一个位置。
  • 在下一轮比较中,不再考虑最后一个位置的元素,重复上述操作。
  • 每轮比较结束后,需要排序的元素数量减一,直到没有需要排序的元素。
  • 排序结束。
  • 这个流程会一直循环,直到所有元素都有序排列为止。

三. 冒泡排序的图解

四. 冒泡排序的代码

// 定义函数,用于实现冒泡排序算法
function bubbleSort(arr: number[]): number[] {
  // 外层循环,控制需要比较的轮数
  for (let i = 0; i < arr.length - 1; i++) {
    // 内层循环,控制每轮需要比较的次数
    for (let j = 0; j < arr.length - 1 - i; j++) {
      // 如果前一个元素比后一个元素大,则交换它们的位置
      if (arr[j] > arr[j + 1]) {
        [arr[j], arr[j + 1]] = [arr[j + 1], arr[j]];
      }
    }
  }
  // 返回排序后的数组
  return arr;
}
// 测试代码
const arr = [3, 44, 38, 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48];
console.log(bubbleSort(arr));
// 输出:[2, 3, 4, 5, 15, 19, 26, 27, 36, 38, 44, 46, 47, 48, 50]

说明:

  • 冒泡排序是一种暴力枚举算法,通过多次循环比较相邻的元素,把最大的元素逐渐冒泡到数组末端。
  • 外层循环:控制排序的趟数,每一轮排序会把最大的元素放到最后,因此每次循环需要比较的元素个数也会逐渐减少。
  • 内层循环:比较相邻元素,如果左边元素比右边元素大,则交换位置。
  • 冒泡排序是一种时间复杂度较高的算法,一般不用于大数据量的排序,但它很容易理解,是一种初学者学习排序算法的好

五. 冒泡排序的时间复杂度

在冒泡排序中,每次比较两个相邻的元素,并交换他们的位置,如果左边的元素比右边的元素大,则交换它们的位置。这样的比较和交换的过程可以用一个循环实现。

  • 在最好的情况下,数组已经是有序的,那么比较和交换的次数是最少的。
  • 在这种情况下,比较次数是n-1次,交换次数是0次,其中n是数组的长度。
  • 在最坏的情况下,数组是逆序的,那么比较和交换的次数是最多的。
  • 在这种情况下,比较次数是n-1次,交换次数是n(n-1)/2次,其中n是数组的长度。
  • 在平均情况下,比较和交换的次数取决于数组的排列方式。
  • 一般来说,平均情况下比较次数是n-1次,交换次数是n(n-1)/4次,其中n是数组的长度。

冒泡排序的时间复杂度分析:

  • 最好情况:当序列已经有序,每次比较和交换操作都不会进行,只需要进行n-1次比较,时间复杂度为O(n)。
  • 最坏情况:当序列完全逆序,需要进行n-1轮比较和n-1次交换操作,时间复杂度为O(n^2)。
  • 平均情况:需要进行的比较和交换操作的次数在所有情况中的平均值,时间复杂度也是O(n^2)。

由此可见,冒泡排序的时间复杂度主要取决于数据的初始顺序,最坏情况下时间复杂度是O(n^2),不适用于大规模数据的排序。

六. 冒泡排序的总结

  • 冒泡排序适用于数据规模较小的情况,因为它的时间复杂度为O(n^2),对于大数据量的排序会变得很慢。
  • 同时,它的实现简单,代码实现也容易理解,适用于学习排序算法的初学者。
  • 但是,在实际的应用中,冒泡排序并不常用,因为它的效率较低。
  • 此外,冒泡排序比较和交换的次数较多,占用更多的存储空间和时间,不适用于处理大数据量的情况。
  • 因此,在实际应用中,冒泡排序通常被更高效的排序算法代替,如快速排序、归并排序等。

以上就是TypeScript实现十大排序算法之冒泡排序示例详解的详细内容,更多关于TypeScript冒泡排序算法的资料请关注我们其它相关文章!

(0)

相关推荐

  • TypeScript十大排序算法插入排序实现示例详解

    目录 一. 插入排序的定义 二. 插入排序的流程 三. 插入排序的图解 四. 插入排序的代码 五. 插入排序的时间复杂度 六. 插入排序的总结 一. 插入排序的定义 插入排序就像是你打扑克牌,你从牌堆顶取一张牌,找到合适的位置插入到已有牌的顺序中,并不断重复这一步骤直到所有的牌都被 插入到合适的位置,最终使得整副牌有序. 与打牌类似,插入排序(Insertion sort)的实现方法是: 首先假设第一个数据是已经排好序的,接着取出下一个数据,在已经排好序的数据中从后往前扫描,找到比它小的数的位置

  • TypeScript类型级别和值级别示例详解

    目录 对值级别编程类型级别编程区分 类型级编程 挑战是如何工作的 挑战 对值级别编程类型级别编程区分 首先,让我们对值级别编程和类型级别编程进行重要区分. 值级别编程让我们编写将在生产中运行的代码即运行期,并为我们的用户提供有用的东西. 类型级别编程帮助我们确保代码在发布之前即编译期不包含错误,在运行期会被完全删除 JavaScript没有类型,所以所有JavaScript都是值级别的代码: // A simple Javascript function: function sum(a, b)

  • Manipulation-TypeScript DOM操作示例解析

    目录 DOM Manipulation 对 HTMLElement 类型的探索 基础案例 Document 接口 Document.getElementById Document.createElement Node 接口 Node.appendChild NodeList 接口 与 NodeListOf 接口 children 和 childNodes 的区别 querySelector 和 querySelectorAll 方法 DOM Manipulation 对 HTMLElement

  • TypeScript 类型级别示例介绍

    介绍 这是一门在线课程,旨在将您的TypeScript技能从中级提升到高级.它将使你深入了解类型系统的基本原理,并指导你完成其高级功能.在这里,你会找到成为TypeScript专家所需的一切-不仅有深入的内容,还有练习新技能的有趣挑战,就像这里的这个. /** * Try assigning "World" to `type Hello`! */ type Hello = "..."; // Type-level unit tests! // If the next

  • TypeScript实现十大排序算法之冒泡排序示例详解

    目录 一. 冒泡排序的定义 二. 冒泡排序的流程 三. 冒泡排序的图解 四. 冒泡排序的代码 五. 冒泡排序的时间复杂度 六. 冒泡排序的总结 一. 冒泡排序的定义 冒泡排序是一种简单的排序方法. 基本思路是通过两两比较相邻的元素并交换它们的位置,从而使整个序列按照顺序排列. 该算法一趟排序后,最大值总是会移到数组最后面,那么接下来就不用再考虑这个最大值. 一直重复这样的操作,最终就可以得到排序完成的数组. 这种算法是稳定的,即相等元素的相对位置不会发生变化. 而且在最坏情况下,时间复杂度为O(

  • Java 十大排序算法之冒泡排序刨析

    目录 冒泡排序原理 冒泡排序API设计 冒泡排序的代码实现 冒泡排序的时间复杂度分析 冒泡排序原理 ①比较相邻的元素,如果前一个元素比后一个元素大,则交换这两个元素的位置 ②对每一对相邻的元素循环上面的步骤,最终最后面的元素就是最大值 冒泡排序API设计 类名 Bubble 构造方法 Bubble:创建Bubble对象 成员方法 1.public static void sort(Comparable[] a):对数组内元素进行排序 2.private static void greater(C

  • JAVA十大排序算法之冒泡排序详解

    目录 冒泡排序 代码实现 代码实现 时间复杂度 算法稳定性 总结 冒泡排序 1.从数组头开始,比较相邻的元素.如果第一个比第二个大(小),就交换它们两个 2.对每一对相邻元素作同样的工作,从开始第一对到尾部的最后一对,这样在最后的元素应该会是最大(小)的数 3.重复步骤1~2,重复次数等于数组的长度,直到排序完成 代码实现 对下面数组实现排序:{24, 7, 43, 78, 62, 98, 82, 18, 54, 37, 73, 9} 代码实现 public class BubbleSort {

  • Java 十大排序算法之插入排序刨析

    目录 插入排序原理 插入排序API设计 插入排序代码实现 插入排序的时间复杂度分析 插入排序原理 ①把所有元素分成已排序和未排序两组 ②找到未排序组的第一个元素,向已经排序的组中进行插入 ③倒序遍历已经排好的元素,依次和待插入的元素进行比较,直到找到一个元素小于等于待插入元素,那么就把待插入元素放到这个位置,其他元素向后移动一位 插入排序API设计 类名 Insertion 构造方法 Insertion():创建Insertion对象 成员方法 1.public static void sort

  • C++实现十大排序算法及排序算法常见问题

    目录 前言 0 概述 1 冒泡排序 2 选择排序 3 插入排序 4 希尔排序 5 归并排序 6 堆排序 7 快速排序 8 计数排序 9 桶排序 10 基数排序 总结 前言 本文为C++实现的十大排序算法及基于排序算法解决的一些常见问题,每一种算法均实际运行,确保正确无误.文中内容为自己的一些理解,如有错误,请大家指正. 0 概述 在十种排序算法中,前七种是比较类排序,后三种是非比较类排序,每种算法的最好.最坏.平均时间复杂度,空间复杂度以及稳定性如下表所示.稳定性是指排序前后相等的元素相对位置保

  • Java 超详细讲解十大排序算法面试无忧

    目录 排序算法的稳定性: 一.选择排序 二.冒泡排序 三.插入排序 四.希尔排序 五.堆排序 六.归并排序 七.快速排序 八.鸽巢排序 九.计数排序 十.基数排序 排序算法的稳定性: 假定在待排序的记录序列中,存在多个具有相同的关键字的记录,如果排序以后,保证这些记录的相对次序保持不变,即在原序列中,a[i]=a[j],且 a[i] 在 a[j] 之前,排序后保证 a[i] 仍在 a[j] 之前,则称这种排序算法是稳定的:否则称为不稳定的. 一.选择排序 每次从待排序的元素中选择最小的元素,依次

  • 可能是你看过最全的十大排序算法详解(完整版代码)

    目录 前言 交集排序 冒泡 简单 快速排序 插入排序 直接插入排序 希尔排序 选择排序 简单选择排序 堆排序 归并排序 二路 多路 非比较类 计数排序 桶排序 基数排序 最后 前言 兄弟们,应上篇数据结构的各位要求,今天我开始工作了,开始肝算法,剑指offer还在路上,我真想开车去接它,奈何码神没有驾照的开车,算了,弄排序算法吧,有点长,耐心看啊,原创不易,你们懂的,先上一张图 可以看出排序算法,还是比较多的,算了,不多说了,你我肝完就是出门自带4年实习经验的! 交集排序 冒泡 冒泡我一般也将它

  • Java 十大排序算法之选择排序刨析

    目录 选择排序原理 选择排序API设计 选择排序代码实现 选择排序的时间复杂度 选择排序原理 ①假设第一个索引处的元素为最小值,和其他值进行比较,如果当前的索引处的元素大于其他某个索引处的值,则假定其他某个索引处的值为最小值,最后找到最小值所在的索引 ②交换第一个索引处和最小值所在的索引处的值 选择排序API设计 类名 Selection 构造方法 Selection():创建Selection对象 成员方法 1.public static void sort(Comparable[] a):对

  • Java 十大排序算法之归并排序刨析

    目录 归并排序原理 归并排序API设计 归并排序代码实现 归并排序的时间复杂度分析 归并排序原理 1.尽可能的一组数据拆分成两个元素相等的子组,并对每一个子组继续拆分,直到拆分后的每个子组的元素个数是1为止. ⒉将相邻的两个子组进行合并成一个有序的大组. 3.不断的重复步骤2,直到最终只有一个组为止. 归并排序API设计 类名 Merge 构造方法 Merge():创建Merge对象 成员方法 1.public static void sort(Comparable[] a):对数组内的元素进行

  • Java 十大排序算法之希尔排序刨析

    目录 希尔排序原理 希尔排序的API设计 希尔排序的代码实现 希尔排序是插入排序的一种,又称"缩小增量排序",是插入排序算法的一种更高效的改进版本. 希尔排序原理 1.选定一个增长量h,按照增长量h作为数据分组的依据,对数据进行分组. 2.对分好组的每一组数据完成插入排序. 3.减小增长量,最小减为1,重复第二步操作. 希尔排序的API设计 类名 Shell 构造方法 Shell():创建Shell对象 成员方法 1.public static void sort(Comparable

随机推荐