01.实现冒泡排序

本文介绍了冒泡排序的基本原理和工作过程,通过实例详细解释了冒泡排序如何进行元素比较和交换,以达到排序的目的。冒泡排序在数组中进行多次迭代,具有二次时间复杂度。挑战读者编写一个JavaScript函数,接收一个未排序的整型数组并返回已排序的数组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

说明

这是排序算法的第一个挑战。给定一个未排序的数组,然后经过排序返回一个有顺序的数组。在接下来的算法挑战中,我们将通过几种不同的方法来实现排序,并在这些不同的方法之间学习一些权衡。虽然大多数现代语言都有内置的这种操作的排序方法,但仍然需要了解一些常见的基本方法,并了解如何实现它们。

冒泡排序

在这里我们将看到冒泡排序。冒泡排序通过重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

该方法需要通过数组进行多次迭代,平均和最差情况下都具有二次时间复杂度。

下面我们来举例说明一下冒泡排序

整形数组未排序前的顺序如下:

[42,20,17,13,28,14,23,15]

第一趟排序,我们从后一个元素15开始,不断与之相邻的元素进行比较,如果比15大,则交换位置,如果比15小,就交换比较元素,第一趟之后,我们得到数组里的最小元素13,而且13也位于数组的第一个元素了,通过不断的排序比较,在比较了数组长度-1次以后,该数组的所有元素已经根据大小排好顺序了


 

任务:写一个函数bubbleSort,它将下列整型数组作为输入,并返回一个排列好的整形数组。

[1,4,2,8,345,123,43,32,5643,63,123,43,2,55,1,234,92]

  • bubbleSort 是一个函数。
  • bubbleSort 返回一个排序的数组。
// helper function to generate a randomly filled array
var array = [];
(function createArray(size) {
  array.push(+(Math.random() * 100).toFixed(0));
  return (size > 1) ? createArray(size - 1) : undefined;
})(12);

function bubbleSort(array) {
  // change code below this line

  // change code above this line
  return array;
}

答案

 

// helper function to generate a randomly filled array
var array = [1,4,2,8,345,123,43,32,5643,63,123,43,2,55,1,234,92];

function bubbleSort(array) {
  // change code below this line
    var i = array.length, j;
    var tempExchangVal;
    while (i > 0) {
        for (j = 0; j < i - 1; j++) {
            if (array[j] > array[j + 1]) {
                tempExchangVal = array[j];
                array[j] = array[j + 1];
                array[j + 1] = tempExchangVal;
            }
        }
        i--;
    }
  // change code above this line
  return array;
}

bubbleSort(array);

 运行结果

[1,1,2,2,4,8,32,43,43,55,63,92,123,123,234,345,5643]

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值