排序算法(转)

小鱼儿 2022-01-25 19:49 240阅读 0赞

1.快速排序

快速排序算法是冒泡排序的一种改进,快速排序也是通过逐渐消除待排序的无序序列中逆序元素来实现排序的

算法思想:

(1) 我们从待排序的记录序列中选取一个记录(通常第一个)作为基准元素(称为key)key=arr[left],然后设置两个变量,left指向数列的最左部,right指向数据的最右部。

在这里插入图片描述

(2) key首先与arr[right]进行比较,如果arr[right]key则我们只需要将right–,right–之后,再拿arr[right]与key进行比较,直到arr[right]<key交换元素为止。

无标题.png

(3) 如果右边存在arr[right]key,则将arr[right]=arr[left],如果arr[left]<key,则只需要将left++,然后再进行arr[left]与key的比较。

在这里插入图片描述

(4) 然后再移动right重复上述步骤

无标题.png

(5) 最后得到 {23 58 13 10 57 62} 65 {106 78 95 85},再对左子数列与右子数列进行同样的操作。最终得到一个有序的数列。

{23 58 13 10 57 62} 65 {106 78 95 85}

{10 13} 23 {58 57 62} 65 {85 78 95} 106

10 13 23 57 58 62 65 78 85 95 106

算法实现:

  1. package com.atguigu.calculate;
  2. import java.util.Arrays;
  3. /**
  4. * @program: game
  5. * @description: 快速排序算法
  6. * @author: Tangseng
  7. * @create: 2019-05-29 15:56
  8. **/
  9. public class QuikSort {
  10. public static void quickSort(int[] arr, int left, int right) {
  11. int pivot;
  12. if (left < right) {
  13. pivot = partition(arr, left, right);
  14. quickSort(arr, left, pivot - 1);
  15. quickSort(arr, pivot + 1, right);
  16. }
  17. }
  18. private static int partition(int[] arr, int left, int right) {
  19. //数组的第一个作为中轴
  20. int key = arr[left];
  21. while (left < right) {
  22. while (left < right && arr[right] >= key) {
  23. right--;
  24. }
  25. //比中轴小的记录移到低端
  26. arr[left] = arr[right];
  27. while (left < right && arr[left] <= key) {
  28. left++;
  29. }
  30. //比中轴大的记录移到高端
  31. arr[right] = arr[left];
  32. }
  33. //中轴记录到尾
  34. arr[right] = key;
  35. //返回中轴的位置
  36. return right;
  37. }
  38. public static void main(String[] args) {
  39. int arr[] = {65, 58, 95, 10, 57, 62, 13, 106, 78,78, 23, 85};
  40. System.out.println("排序前:" + Arrays.toString(arr));
  41. quickSort(arr, 0, arr.length - 1);
  42. System.out.println("排序后:" + Arrays.toString(arr));
  43. }
  44. }

发表评论

表情:
评论列表 (有 0 条评论,240人围观)

还没有评论,来说两句吧...

相关阅读

    相关 算法--排序算法

    首发网址:[算法--排序算法\_IT利刃出鞘的博客-CSDN博客][--_IT_-CSDN] 其他网址 [一文搞定十大经典排序算法(Java实现) - 简书][Java

    相关 排序算法

    1.快速排序 快速排序算法是冒泡排序的一种改进,快速排序也是通过逐渐消除待排序的无序序列中逆序元素来实现排序的 算法思想: (1) 我们从待排序的记录序列中选取一个记