技术文摘
十大经典排序算法之总结(附 Java 代码实现)
2024-12-31 11:43:06 小编
十大经典排序算法之总结(附 Java 代码实现)
在计算机科学中,排序算法是至关重要的一部分。它们在数据处理、搜索优化等众多领域发挥着关键作用。以下是对十大经典排序算法的总结,并附上 Java 代码实现示例。
冒泡排序(Bubble Sort):通过反复比较相邻元素并交换位置,将最大的元素逐步“浮”到数组的末尾。
选择排序(Selection Sort):每次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置。
插入排序(Insertion Sort):将待排序的元素插入到已排序的部分合适的位置。
希尔排序(Shell Sort):对插入排序的改进,通过缩小增量来分组排序。
快速排序(Quick Sort):选取一个基准元素,将数组分为小于和大于基准的两部分,然后对这两部分分别排序。
归并排序(Merge Sort):将数组分成两半,分别排序后再合并。
堆排序(Heap Sort):利用堆这种数据结构进行排序。
计数排序(Counting Sort):适用于一定范围内的整数排序。
桶排序(Bucket Sort):将数据分到不同的桶中,对每个桶内的数据单独排序。
基数排序(Radix Sort):按照数字的每一位进行排序。
以下是冒泡排序的 Java 代码实现示例:
public class BubbleSort {
public static void bubbleSort(int[] arr) {
int n = arr.length;
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
public static void main(String[] args) {
int[] arr = {64, 34, 25, 12, 22, 11, 90};
System.out.println("排序前的数组为:");
for (int num : arr) {
System.out.print(num + " ");
}
bubbleSort(arr);
System.out.println("\n 排序后的数组为:");
for (int num : arr) {
System.out.print(num + " ");
}
}
}
不同的排序算法在时间复杂度、空间复杂度和适用场景上各有特点。了解和掌握这些排序算法,有助于我们在实际编程中根据具体需求选择最合适的算法,提高程序的效率和性能。
- document.referrer 为何无法直接修改
- Vite打包时怎样合并重复套件
- jQuery AJAX加载图片时解决浏览器缓存致回调函数无法执行问题的方法
- 外部脚本按顺序加载失败是否与JavaScript代码顺序相关
- 同一浏览器版本中滚动条样式不同的原因
- 异步回调中this指向全局对象window而非预期对象的原因
- CSS 实现透明背景且 1px 边框六边形的方法
- JQuery点击按钮弹窗加载TAB数据,怎样防止TAB滚动加载下一页时分类混淆
- Flex布局剩余空间分配不均:flex: 1为何不能平等分配空间
- SVG 实现水位动态变化与颜色控制的方法
- 标签display: inline-block使父元素有高度而display: inline让父元素高度为0的原因
- 使用 mask 引入本地图片怎样解决跨域问题
- 移动端 rem 计算引发 CSS 变形问题及避免方法
- React JSX函数中如何确保组件正确渲染
- JavaScript 实现 CSS sticky 效果:元素高度超浏览器窗口高度的处理方法