云主机测评网云主机测评网云主机测评网

云主机测评网
www.yunzhuji.net

java排序算法有哪些

Java中的排序算法包括冒泡排序、选择排序、插入排序、快速排序归并排序和希尔排序等。这些算法在处理数据排序问题时具有不同的效率和适用场景。

在计算机科学中,排序算法是一类重要的算法,用于将一组无序的数据元素按照一定的顺序重新排列,Java语言中常用的排序算法包括冒泡排序、选择排序、插入排序、希尔排序、归并排序快速排序、堆排序、计数排序、桶排序和基数排序等,以下将详细解释这些排序算法的特点、原理和实现方式:

(图片来源网络,侵删)

1、冒泡排序(Bubble Sort)

算法原理:通过重复遍历要排序的数列,一次比较两个相邻元素,如果它们的顺序错误就把它们交换过来。

时间复杂度:平均和最坏情况下为O(n^2),最好情况下为O(n)。

空间复杂度:O(1),原地排序。

稳定性:稳定。

(图片来源网络,侵删)

代码示例

“`java

public 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;

}

}

“`

2、选择排序(Selection Sort)

算法原理:首先在未排序序列中找到最小(或最大)元素,存放到排序序列的起始位置,再从剩余未排序元素中继续寻找最小(或最大)元素,然后放到已排序序列的末尾。

时间复杂度:无论最好、平均还是最坏情况均为O(n^2)。

空间复杂度:O(1),原地排序。

稳定性:不稳定。

代码示例

“`java

public void selectionSort(int[] arr) {

int n = arr.length;

for (int i = 0; i < n 1; i++) {

int minIndex = i;

for (int j = i + 1; j < n; j++) {

if (arr[j] < arr[minIndex]) {

minIndex = j;

}

}

int temp = arr[minIndex];

arr[minIndex] = arr[i];

arr[i] = temp;

}

}

“`

3、插入排序(Insertion Sort)

算法原理:将数组中的每个待排序元素插入到已经排好序的数列中的适当位置,以达到排序的目的。

时间复杂度:平均和最坏情况下为O(n^2),最好情况下为O(n)。

空间复杂度:O(1),原地排序。

稳定性:稳定。

代码示例

“`java

public void insertionSort(int[] arr) {

for (int i = 1; i < arr.length; i++) {

int key = arr[i];

int j = i 1;

while (j >= 0 && arr[j] > key) {

arr[j + 1] = arr[j];

j;

}

arr[j + 1] = key;

}

}

“`

4、希尔排序(Shell Sort)

算法原理:基于插入排序的一种算法,通过特定的间隔进行排序,然后逐步缩小间隔,直到间隔为1。

时间复杂度:平均和最坏情况下为O(n^2),最好情况下为O(nlogn)。

空间复杂度:O(1),原地排序。

稳定性:不稳定。

代码示例

“`java

public void shellSort(int[] arr) {

int len = arr.length;

for (int gap = len / 2; gap > 0; gap /= 2) {

for (int i = gap; i < len; i++) {

int j = i gap;

int temp = arr[i];

while (j >= 0 && arr[j] > temp) {

arr[j + gap] = arr[j];

j = gap;

}

arr[j + gap] = temp;

}

}

}

“`

5、归并排序(Merge Sort)

算法原理:采用分治法的一个典型应用,将数组分成两半,分别排序,然后将结果合并。

时间复杂度:所有情况下均为O(nlogn)。

空间复杂度:O(n),需要额外空间。

稳定性:稳定。

代码示例

“`java

public void mergeSort(int[] arr, int l, int r) {

if (l >= r) return;

int mid = l + (r l) / 2;

mergeSort(arr, l, mid);

mergeSort(arr, mid + 1, r);

merging(arr, l, mid, r);

}

“`

6、快速排序(Quick Sort)

算法原理:采用分治法,选择一个基准元素,将数组分为两部分,一边都比基准小,另一边都比基准大,然后递归地进行排序。

时间复杂度:平均和最好情况下为O(nlogn),最坏情况下为O(n^2)。

空间复杂度:O(logn)。

稳定性:不稳定。

代码示例

“`java

public void quickSort(int[] arr, int low, int high) {

if (low < high) {

int pi = partition(arr, low, high);

quickSort(arr, low, pi 1);

quickSort(arr, pi + 1, high);

}

}

“`

7、堆排序(Heap Sort)

算法原理:利用堆数据结构进行排序,先将待排序的序列构造成一个大顶堆,然后将堆顶的最大元素交换到序列的末尾,然后再调整结构成大顶堆,反复进行。

时间复杂度:所有情况下均为O(nlogn)。

空间复杂度:O(1),原地排序。

稳定性:不稳定。

代码示例

“`java

public void heapSort(int[] arr) {

buildMaxHeap(arr);

for (int i = arr.length 1; i > 0; i) {

swap(arr, 0, i);

maxHeapify(arr, 0, i);

}

}

“`

8、计数排序(Counting Sort)

算法原理:非比较排序的一种,当待排序的元素都是整数且范围已知时,用计数排序可以达到线性的时间复杂度。

时间复杂度:所有情况下均为O(n+k)。

空间复杂度:O(k)。

稳定性:稳定。

代码示例

“`java

public void countingSort(int[] arr) {

int maxValue = getMaxValue(arr);

int[] countArray = new int[maxValue + 1];

for (int value : arr) {

countArray[value]++;

}

int sortedIndex = 0;

for (int countIndex = 0; countIndex <= maxValue; countIndex++) {

while (countArray[countIndex]!= 0) {

arr[sortedIndex++] = countIndex;

}

}

}

“`

9、桶排序(Bucket Sort)

算法原理:将数组分到有限数量的桶里,每个桶再个别排序(有可能使用不同的排序算法),最后按照顺序把每个桶里的元素列出来。

时间复杂度:平均和最好情况下为O(n),最坏情况下为O(n^2)。

空间复杂度:O(n+k)。

稳定性:稳定。

适用场景:当输入均匀分布在某个区间时效果最好。

代码示例:略。

10、基数排序(Radix Sort)

算法原理:按低位先排序,然后收集;再按高位排序,然后再收集;依次类推,直到最高位。

时间复杂度:所有情况下均为O(nk)。

空间复杂度:O(n+k)。

稳定性:稳定。

适用场景:适合大量数据的排序,特别是位数相差不大的情况。

代码示例:略。

通过上述介绍,可以看到每种排序算法都有其独特的应用场景和性能特点,在选择排序算法时,应根据具体需求考虑数据量大小、数据特性以及是否稳定等因素,若对稳定性有要求,则可以考虑冒泡排序、插入排序、归并排序、计数排序、桶排序和基数排序等;若数据量较大且分布均匀,则桶排序可能是更好的选择,了解和掌握各种排序算法的原理和应用,对于提高数据处理效率具有重要意义。

打赏
版权声明:主机测评不销售、不代购、不提供任何支持,仅分享信息/测评(有时效性),自行辨别,请遵纪守法文明上网。
文章名称:《java排序算法有哪些》
文章链接:https://www.yunzhuji.net/yunfuwuqi/179896.html

评论

  • 验证码