高效排序算法:如何在实际项目中选择合适的方法?
创作时间:
作者:
@小白创作中心
高效排序算法:如何在实际项目中选择合适的方法?
引用
CSDN
1.
https://blog.csdn.net/weixin_42554191/article/details/143228155
高效排序算法是用于处理大量数据的排序方法,它们通常具有更优的时间复杂度和空间复杂度。下面将详细介绍四种高效排序算法:归并排序、快速排序、堆排序和基数排序。
1. 归并排序(Merge Sort)
归并排序是一种分治算法,它将数组分成两个子数组,递归地排序这两个子数组,然后将它们合并成一个有序的数组。
特点
- 时间复杂度:最坏、平均和最佳情况均为 (O(n \log n))。
- 空间复杂度:(O(n))(需要额外的数组空间)。
- 稳定性:稳定。
实现示例
function mergeSort(arr) {
if (arr.length <= 1) return arr; // 基础情况
const mid = Math.floor(arr.length / 2); // 找到中间索引
const left = mergeSort(arr.slice(0, mid)); // 递归排序左半部分
const right = mergeSort(arr.slice(mid)); // 递归排序右半部分
return merge(left, right); // 合并两个有序数组
}
function merge(left, right) {
const result = [];
let i = 0, j = 0;
// 合并两个有序数组
while (i < left.length && j < right.length) {
if (left[i] < right[j]) {
result.push(left[i++]);
} else {
result.push(right[j++]);
}
}
// 将剩余元素添加到结果中
return result.concat(left.slice(i)).concat(right.slice(j));
}
// 示例
const array1 = [38, 27, 43, 3, 9, 82, 10];
console.log(mergeSort(array1)); // [3, 9, 10, 27, 38, 43, 82]
2. 快速排序(Quick Sort)
快速排序是一种分治排序算法,它选择一个"基准"元素,然后将数组分成比基准小的部分和比基准大的部分,递归地对这两个部分进行排序。
特点
- 时间复杂度:最坏情况是 (O(n^2)),平均和最佳情况是 (O(n \log n))。
- 空间复杂度:(O(\log n))(递归栈空间)。
- 稳定性:不稳定。
实现示例
function quickSort(arr) {
if (arr.length <= 1) return arr; // 基础情况
const pivot = arr[Math.floor(arr.length / 2)]; // 选择基准元素
const left = arr.filter(x => x < pivot); // 小于基准
const middle = arr.filter(x => x === pivot); // 等于基准
const right = arr.filter(x => x > pivot); // 大于基准
return [...quickSort(left), ...middle, ...quickSort(right)]; // 递归排序并合并
}
// 示例
const array2 = [10, 7, 8, 9, 1, 5];
console.log(quickSort(array2)); // [1, 5, 7, 8, 9, 10]
3. 堆排序(Heap Sort)
堆排序是一种基于比较的排序算法,它利用堆数据结构的性质,将待排序的元素构建成一个最大堆(或最小堆),然后反复提取堆顶元素进行排序。
特点
- 时间复杂度:最坏、平均和最佳情况均为 (O(n \log n))。
- 空间复杂度:(O(1))(就地排序)。
- 稳定性:不稳定。
实现示例
function heapSort(arr) {
const n = arr.length;
// 建立最大堆
for (let i = Math.floor(n / 2) - 1; i >= 0; i--) {
heapify(arr, n, i);
}
// 一个个取出最大元素
for (let i = n - 1; i > 0; i--) {
[arr[0], arr[i]] = [arr[i], arr[0]]; // 交换
heapify(arr, i, 0); // 重建堆
}
return arr;
}
function heapify(arr, n, i) {
let largest = i; // 初始化最大元素为根节点
const left = 2 * i + 1; // 左子节点
const right = 2 * i + 2; // 右子节点
// 如果左子节点比根节点大
if (left < n && arr[left] > arr[largest]) {
largest = left;
}
// 如果右子节点比最大值大
if (right < n && arr[right] > arr[largest]) {
largest = right;
}
// 如果最大值不是根节点
if (largest !== i) {
[arr[i], arr[largest]] = [arr[largest], arr[i]]; // 交换
heapify(arr, n, largest); // 递归
}
}
// 示例
const array3 = [3, 0, 2, 5, -1, 4, 1];
console.log(heapSort(array3)); // [-1, 0, 1, 2, 3, 4, 5]
4. 基数排序(Radix Sort)
基数排序是一种非比较的排序算法,它通过将数字分解为数字位进行排序。基数排序可以使用稳定的排序算法(如计数排序)进行子排序。
特点
- 时间复杂度:(O(nk)),其中 (n) 是元素数量,(k) 是数字的位数。
- 空间复杂度:(O(n + k))(可能需要额外的空间)。
- 稳定性:稳定。
实现示例
function countingSortForRadix(arr, exp) {
const output = new Array(arr.length);
const count = new Array(10).fill(0);
// 统计每位数字的出现次数
for (let i = 0; i < arr.length; i++) {
count[Math.floor(arr[i] / exp) % 10]++;
}
// 改变count[i]使其包含当前位置
for (let i = 1; i < 10; i++) {
count[i] += count[i - 1];
}
// 构建输出数组
for (let i = arr.length - 1; i >= 0; i--) {
output[count[Math.floor(arr[i] / exp) % 10] - 1] = arr[i];
count[Math.floor(arr[i] / exp) % 10]--;
}
// 复制输出数组到原数组
for (let i = 0; i < arr.length; i++) {
arr[i] = output[i];
}
}
function radixSort(arr) {
const max = Math.max(...arr);
// 对每一位进行排序
for (let exp = 1; Math.floor(max / exp) > 0; exp *= 10) {
countingSortForRadix(arr, exp);
}
return arr;
}
// 示例
const array4 = [170, 45, 75, 90, 802, 24, 2, 66];
console.log(radixSort(array4)); // [2, 24, 45, 66, 75, 90, 170, 802]
总结
- 归并排序:适合大型数据集的稳定排序,使用额外空间。
- 快速排序:平均情况下非常快,但最坏情况性能较差;适合大多数场景。
- 堆排序:高效且不需要额外空间,但不稳定,适合内存有限的场景。
- 基数排序:适合特定类型的整数或字符串排序,效率高但实现复杂。
这些高效排序算法在实际应用中广泛使用,选择合适的排序算法取决于数据的特性和具体需求。
热门推荐
开源:意义、优势、示例等
戒烟后,如何加速肺部自清洁?
痘痘肌必看!日本医师公开11种「抗痘食物」+7种「致痘食物」,吃对才能有好皮肤
如何在小区建设中精准把握居民需求?
九牛问津:博士申请材料清单,打造完美申请的全面指南
中医揭秘:对抗“耳鸣”最快的方式,运动第三,食疗第二,第一名竟是它!
庄辉、卢洪洲、张文宏3位中国专家名字命名新菌种
运动面料热舒适性能测试与分析
线性代数导学:点积与叉积的作用
缓解狗狗腿痒困扰
JTUMS:维格列汀和瑞格列净联合二甲双胍治疗2型糖尿病的疗效和安全性
【深度解读】周岭《认知觉醒》:一场思维升级的探索之旅,以及同类力作推荐
在南宁,邂逅历史与现代的交融
原神莫娜元素战技机制解析:掌握技能特点与运用要点
山东产氢氧化铝:生产工艺、应用领域与市场前景
狗狗便便出现白色长虫?这份驱虫指南请收好!
如何通过日常习惯改善肺功能
开源项目中的版权责任如何确定
核酸浓度测量中的230nm、260nm、280nm:意义与应用
中国每年需进口200万吨棉花,却将大量新疆棉出口,到底为什么?
大模型工作原理深度解剖:从Transformer架构到知识涌现的范式革命
武元衡:唐朝宰相、诗人二度拜相,主张强势对抗藩镇
白花蛇舌草:清热解毒的道地中药材
数字化基层治理研究报告发布:17个优秀案例解析基层治理创新实践
CubeDiff:重新利用基于扩散的图像模型来生成360°全景图
中山市北部快线公路规划详解:全长50公里,分段建设推进中
如何在租赁市场中找到合适的租房选择?这种选择需要依据哪些标准?
让废弃矿山重焕生机——江西省地质局第三大队探索生态与文化共生的创新实践
小马宝莉人物:友谊与魔法的多彩世界
客诉流程的优化与处理方案