`
异步获取爱
  • 浏览: 80020 次
  • 性别: Icon_minigender_1
  • 来自: 大男子主义世界
社区版块
存档分类
最新评论

Shaker 排序法 - 改良的冒泡排序

J# 
阅读更多
    說明
請看看之前介紹過的氣泡排序法:
  
  for(i = 0; i < MAX-1 && flag == 1; i++) {
        flag = 0;
        for(j = 0; j < MAX-i-1; j++) {
            if(number[j+1] < number[j]) {
                SWAP(number[j+1], number[j]);
                flag = 1;
            }
        }
    }



事實上這個氣泡排序法已經不是單純的氣泡排序了,它使用了旗標與右端左移兩個方法來改進排序的效能,而Shaker排序法使用到後面這個觀念進一步改良氣泡排序法。

    解法
在上面的氣泡排序法中,交換的動作並不會一直進行至陣列的最後一個,而是會進行至MAX-i-1,所以排序的過程中,陣列右方排序好的元素會一直增加,使得左邊排序的次數逐漸減少,如我們的例子所示:

排序前:95 27 90 49 80 58 6 9 18 50

   1. 27 90 49 80 58 6 9 18 50 [95] 95浮出
   2. 27 49 80 58 6 9 18 50 [90 95] 90浮出
   3. 27 49 58 6 9 18 50 [80 90 95] 80浮出
   4. 27 49 6 9 18 50 [58 80 90 95] ......
   5. 27 6 9 18 49 [50 58 80 90 95] ......
   6. 6 9 18 27 [49 50 58 80 90 95] ......
   7. 6 9 18 [27 49 50 58 80 90 95]


方括號括住的部份表示已排序完畢,Shaker排序使用了這個概念,如果讓左邊的元素也具有這樣的性質,讓左右兩邊的元素都能先排序完成,如此未排序的元素會集中在中間,由於左右兩邊同時排序,中間未排序的部份將會很快的減少。

方法就在於氣泡排序的雙向進行,先讓氣泡排序由左向右進行,再來讓氣泡排序由右往左進行,如此完成一次排序的動作,而您必須使用left與right兩個旗標來記錄左右兩端已排序的元素位置。

一個排序的例子如下所示:

排序前:45 19 77 81 13 28 18 19 77 11

往右排序:19 45 77 13 28 18 19 77 11 [81]
向左排序:[11] 19 45 77 13 28 18 19 77 [81]

往右排序:[11] 19 45 13 28 18 19 [77 77 81]
向左排序:[11 13] 19 45 18 28 19 [77 77 81]

往右排序:[11 13] 19 18 28 19 [45 77 77 81]
向左排序:[11 13 18] 19 19 28 [45 77 77 81]

往右排序:[11 13 18] 19 19 [28 45 77 77 81]
向左排序:[11 13 18 19 19] [28 45 77 77 81]

如上所示,括號中表示左右兩邊已排序完成的部份,當left > right時,則排序完成。
public class Sort {
    public static void sort(int[] number) {
        int left = 0;
        int right = number.length - 1;
        int shift = 0; 

        while(left < right) { 
            // 向右進行氣泡排序 
            for(int i = left; i < right; i++) { 
                if(number[i] > number[i+1]) { 
                    swap(number, i, i+1); 
                    shift = i; 
                } 
            } 
            right = shift; 

            // 向左進行氣泡排序 
            for(int i = right; i > left; i--) { 
                if(number[i] < number[i-1]) { 
                    swap(number, i ,i-1); 
                    shift = i; 
                } 
            } 
            left = shift; 
        } 
    }

    private static void swap(int[] number, int i, int j) {
        int t = number[i]; 
        number[i] = number[j]; 
        number[j] = t;
    }
} 
分享到:
评论

相关推荐

    C经典算法之Shaker 排序法 - 改良的气泡排序

    ### C经典算法之Shaker排序法 - 改良的气泡排序 #### 一、引言 在计算机科学中,排序算法是数据处理中的一个重要环节。气泡排序是一种基础且直观的排序方法,但它的效率相对较低。为提高排序效率,人们发展出了...

    C语言经典算法大全(程序员必备).rar

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 � 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表...

    各种经典算法

    各种经典算法(总有一款你喜欢),河內塔 ...Shaker 排序法 - 改良的氣泡排序 Heap 排序法 - 改良的選擇排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合併排序法 基數排序法 。。。

    java开发经典算法

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表) 插补...

    经典常用算法(含代码)

    经典常用算法解析与实现,通过Java C语言分别实现各种算法,...Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序等

    经典算法大全,常用的算法都在这里

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜

    C语言经典算法大全(几十个经典案例,都有详尽代码)

    C语言经典几十个经典案例,都有详尽 ...Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 循序搜寻法(使用卫兵)

    蓝桥杯信息学奥赛练习试题

    蓝桥杯信息学奥赛练习试题,几十个必做题目,都有详尽解答和代码 ...Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基

    JAVA经典算法各种排序算法

    Shaker 排序法 - 改良的氣泡排序 Heap 排序法 - 改良的選擇排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合併排序法 基數排序法 搜尋 循序搜尋法(使用衛兵) 二分搜尋法(搜尋原則的代表)...

    C语言经典算法大全

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表)...

    C-Program-examples.rar_2维码 C语言_c 卡牌游戏_字串核对_背包问题_蒙塔卡罗法

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表) ...

    c语言经典算法包括老掉牙,汉诺塔,三色旗

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表) ...

    数据结构与算法

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表)...

    经典常用算法 河内塔

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表)...

    java各种经典算法

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表)...

    Java和C语言实现各种经典算法(含代码图例)

    Shaker 排序法 - 改良的气泡排序 Heap 排序法 - 改良的选择排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合并排序法 基数排序法 搜寻 循序搜寻法(使用卫兵) 二分搜寻法(搜寻原则的代表)...

    java 常见算法大全

    Shaker 排序法 - 改良的氣泡排序 Heap 排序法 - 改良的選擇排序 快速排序法(一) 快速排序法(二) 快速排序法(三) 合併排序法 基數排序法 搜尋 循序搜尋法(使用衛兵) 二分搜尋法(搜尋原則的代表) ...

    Java实现几种常见排序方法-直插、冒泡、选择、快排、堆排等

    除了上述提及的排序算法之外,文档中还提到了希尔排序(Shell Sort)、基数排序(Radix Sort)、鸡尾酒排序(Cocktail Shaker Sort)、桶排序(Bucket Sort)和鸽巢排序(Bucket Sort)等多种排序方法。这些排序算法...

Global site tag (gtag.js) - Google Analytics