簡單講解奇偶排序算法及在Java數(shù)組中的實現(xiàn)
奇偶排序是一個比較有個性的排序,基本思路是奇數(shù)列排一趟序,偶數(shù)列排一趟序,再奇數(shù)排,再偶數(shù)排,直到全部有序
舉例吧,
待排數(shù)組
[6 2 4 1 5 9]
第一次比較奇數(shù)列,奇數(shù)列與它的鄰居偶數(shù)列比較,如6和2比,4和1比,5和9比
[6 2 4 1 5 9]
交換后變成
[2 6 1 4 5 9]
第二次比較偶數(shù)列,即6和1比,5和5比
[2 6 1 4 5 9]
交換后變成
[2 1 6 4 5 9]
第三趟又是奇數(shù)列,選擇的是2,6,5分別與它們的鄰居列比較
[2 1 6 4 5 9]
交換后
[1 2 4 6 5 9]
第四趟偶數(shù)列
[1 2 4 6 5 9]
一次交換
[1 2 4 5 6 9]
Java實現(xiàn):
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,則不再整體循環(huán)了。跟冒泡排序一樣,可以減少最后一次內(nèi)層循環(huán)。
- Java對數(shù)組實現(xiàn)選擇排序算法的實例詳解
- 詳解Java數(shù)據(jù)結(jié)構(gòu)和算法(有序數(shù)組和二分查找)
- Java數(shù)組常用排序算法實例小結(jié)
- Java算法實現(xiàn)調(diào)整數(shù)組順序使奇數(shù)位于偶數(shù)之前的講解
- 面試題:Java 實現(xiàn)查找旋轉(zhuǎn)數(shù)組的最小數(shù)字
- java實現(xiàn)二分法查找出數(shù)組重復(fù)數(shù)字
- Java查找不重復(fù)無序數(shù)組中是否存在兩個數(shù)字的和為某個值
- Java數(shù)組高級算法與Arrays類常見操作小結(jié)【排序、查找】
相關(guān)文章
Spring mvc工作原理_動力節(jié)點Java學院整理
這篇文章主要為大家詳細介紹了Spring mvc工作原理的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08Java多線程高并發(fā)中的Fork/Join框架機制詳解
本文主要介紹了 Java 多線程高并發(fā)中的 Fork/Join 框架的基本原理和其使用的工作竊取算法(work-stealing)、設(shè)計方式和部分實現(xiàn)源碼,感興趣的朋友跟隨小編一起看看吧2021-11-11ThreadPoolExecutor線程池原理及其execute方法(詳解)
下面小編就為大家?guī)硪黄猅hreadPoolExecutor線程池原理及其execute方法(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06SpringCloud使用feign調(diào)用錯誤的問題
這篇文章主要介紹了SpringCloud使用feign調(diào)用錯誤的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06