一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java數據結構與算法之快速排序詳解

java數據結構與算法之快速排序詳解

2020-09-23 13:41android小豬 Java教程

這篇文章主要介紹了java數據結構與算法之快速排序,結合實例形式詳細分析了快速排序的原理、實現步驟、相關操作技巧與注意事項,需要的朋友可以參考下

本文實例講述了java數據結構算法快速排序。分享給大家供大家參考,具體如下:

交換類排序的另一個方法,即快速排序。

快速排序:改變了冒泡排序中一次交換僅能消除一個逆序的局限性,是冒泡排序的一種改進;實現了一次交換可消除多個逆序。通過一趟排序將要排序的數據分割成獨立的兩部分,其中一部分的所有數據都比另外一部分的所有數據都要小,然后再按此方法對這兩部分數據分別進行快速排序,整個排序過程可以遞歸進行,以此達到整個數據變成有序序列。

步驟:

1、從數列中挑出一個元素,稱為 "基準"(pivot);
2、重新排序數列,所有元素比基準值小的擺放在基準前面,所有元素比基準值大的擺在基準的后面(相同的數可以到任一邊)。在這個分區退出之后,該基準就處于數列的中間位置。這個稱為分區(partition)操作。
3、遞歸地(recursive)把小于基準值元素的子數列和大于基準值元素的子數列排序。

遞歸的最底部情形,是數列的大小是零或一,也就是永遠都已經被排序好了。雖然一直遞歸下去,但是這個算法總會退出,因為在每次的迭代(iteration)中,它至少會把一個元素擺到它最后的位置去。

算法實現代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package exp_sort;
public class QuickSort {
  public static void Qsort(int array[], int left, int right) {
    int pos;
    if (left < right) {
      pos = quickSort(array, left, right);
      //遞歸排序
      Qsort(array, left, pos - 1);
      Qsort(array, pos + 1, right);
    }
  }
  /**
   * 一趟快速排序
   *
   * @param array
   * @param left
   * @param right
   * @return
   */
  public static int quickSort(int array[], int left, int right) {
    int low, high;
    int temp = array[left]; // 選擇基準記錄(樞紐元)
    low = left;
    high = right;
    while (low < high) {
      // high從右到左找小于temp的記錄
      while (low < high && array[high] >= temp) {
        high--;
      }
      // 找到小于temp的記錄則交換
      if (low < high) {
        array[low] = array[high];
        low++;
      }
      // low從左到右找到大于temp的記錄
      while (low < high && array[low] < temp) {
        low++;
      }
      // 找到大于temp的記錄,則交換
      if (low < high) {
        array[high] = array[low];
        high--;
      }
    }
    //將游標放在當前位置,此時low=high
    array[low] = temp;
    return low;
  }
  public static void main(String[] args) {
    // TODO Auto-generated method stub
    int array[] = { 38, 62, 35, 77, 55, 14, 35, 98 };
    Qsort(array, 0, 7);
    for (int i = 0; i < array.length; i++) {
      System.out.print(array[i] + " ");
    }
    System.out.println("\n");
  }
}

樞紐元的選取:

1、基本的快速排序:選取地一個元素作為樞紐元。實際中應盡量避免將第一個元素作為樞紐元(極端情況是:初始狀態是已排好序或者反序的)。

2、隨機化快排序 :  隨機的選取樞紐元。

3、平衡快排 : 三數中值分割法:樞紐元的最好選擇是數組中的中值,該中值,即左端、右端和中心位置上的三個元素的中值(推薦)。

算法分析:該算法是在實踐中最快的一種排序算法,它的平均運行時間是O(N log N),該算法之所以快,主要是由于非常精煉和高度優化的內部循環。它的最壞情況的性能是O(N^2),但是這種情況可以改變。快速排序是一種分治的遞歸算法。該算法比歸并排序算法排序快。

1、最壞情況的分析

當樞紐元是最小元素時,此時就相當于是對整個數組進行遞歸排序,時間復雜度為:O(N^2)

2、最好情況的分析

樞紐元正好位于中間,此時是對兩個子數組進行遞歸排序,時間復雜度是:O(N log N),這和歸并排序的分析完全相同。

3、平均情況的分析

時間復雜度是:O( N log N)

希望本文所述對大家java程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产欧美日韩精品一区二区三区 | 亚洲高清一区二区三区四区 | 男女车车好快的车车免费网站 | 亚洲欧美精品一区天堂久久 | 色琪琪原网站亚洲香蕉 | 无码精品一区二区三区免费视频 | 羞羞麻豆国产精品1区2区3区 | 色吧 | 跪在老师脚下吃丝袜脚 | 国产精品99久久 | 日韩精品亚洲一级在线观看 | 国产成人亚洲精品91专区手机 | 成人毛片高清视频观看 | 亚洲免费视频一区 | 免费观看韩剧网站在线观看 | 国产精品免费看久久久香蕉 | 日本最大的黄色网站 | 四虎一影院区永久精品 | 四虎影院在线免费 | 变形金刚第一部 | 99ri在线精品视频在线播放 | 久久一本岛在免费线观看2020 | 2048论坛永久入口 原创合集 | 99这里只有精品在线 | 羞羞漫画免费漫画页面在线看漫画秋蝉 | 国产精品猎奇系列在线观看 | 四虎国产欧美成人影院 | 美女福利网站 | 久九九精品免费视频 | 久久99亚洲热最新地址获取 | 亚洲香蕉视频 | 亚洲高清视频在线 | 免费国产午夜高清在线视频 | blacked黑人hd2021| 青青网在线视频 | 国产人成精品午夜在线观看 | 5g影院天天5g爽天天看 | 欧美一级免费看 | 香蕉视频在线观看网站 | 欧美亚洲一区二区三区在线 | 国产成人在线视频 |