比较函数可以接受两个参数,分别表示要比较的两个元素。如果要按照升序排序,比较函数可以返回一个小于0的值;如果要按照降序排序,比较函数可以返回一个大于0的值。
以下是一个例子,演示如何对一个简单数组按照升序排序:
const arr = [10, 2, 5, 1, 9]; arr.sort((a, b) => a - b); console.log(arr); // [1, 2, 5, 9, 10]
如果要按照降序排序,比较函数可以返回b-a。
冒泡排序:
冒泡排序是一种基本的排序算法,它的原理是比较相邻的元素,如果前面的元素比后面的元素大,就交换它们,重复这个过程,直到整个序列都有序。
冒泡排序的具体实现步骤如下:
- 从序列的第一个元素开始,比较相邻的两个元素,如果前一个元素大于后一个元素,就交换它们的位置。
- 对序列中的每一对相邻元素都进行比较和交换。
- 重复执行上述步骤,直到序列最后一个元素已经排好序。
- 最后,输出排序好的序列。
示例代码如下:
def bubble_sort(arr): n = len(arr) for i in range(n-1): for j in range(n-i-1): if arr[j] > arr[j+1]: arr[j], arr[j+1] = arr[j+1], arr[j] return arr