簡單講解奇偶排序演算法及在Java數組中的實現_java

來源:互聯網
上載者:User

奇偶排序是一個比較有個性的排序,基本思路是奇數列排一趟序,偶數列排一趟序,再奇數排,再偶數排,直到全部有序

舉例吧,

待排數組

[6 2 4 1 5 9]

第一次比較奇數列,奇數列與它的鄰居偶數列比較,如6和2比,4和1比,5和9比

[6 2 4 1 5 9]

交換後變成

[2 6 1 4 5 9]

第二次比較偶數列,即6和1比,5和5比

[2 6 1 4 5 9]

交換後變成

[2 1 6 4 5 9]

第三趟又是奇數列,選擇的是2,6,5分別與它們的鄰居列比較

[2 1 6 4 5 9]

交換後

[1 2 4 6 5 9]

第四趟偶數列

[1 2 4 6 5 9]

一次交換

[1 2 4 5 6 9]

Java實現:

static void oddEvensort(int[] ary) {   //奇偶排序      boolean flag = true;   while (flag) {    boolean odd = false, even = false;    for (int i = 0; i < ary.length - 1; i+=2) {     if (ary[i] > ary[i + 1]) {      ary[i] = ary[i + 1] + 0 * (ary[i + 1] = ary[i]);      odd = true;     }    }    for (int i = 1; i < ary.length - 1; i+=2) {     if (ary[i] > ary[i + 1]) {      ary[i] = ary[i + 1] + 0 * (ary[i + 1] = ary[i]);      even = true;     }    }    flag = odd || even; //若為false,表示不論奇偶序列,一個合格比較都沒有   }  } 

上面的 flag = odd || even;    有一個為true,表示還在交換, 那麼最後只有 都為 false時,flag才為false。
改寫成 flag = odd && even;    有一個為false,則不再整體迴圈了。跟冒泡排序一樣,可以減少最後一次內層迴圈。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.