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

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

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - 簡單講解奇偶排序算法及在Java數組中的實現

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

2020-04-18 12:14匆忙擁擠repeat JAVA教程

這篇文章主要介紹了奇偶排序算法及Java數組的實現,奇偶排序的時間復雜度為O(N^2),需要的朋友可以參考下

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

舉例吧,

待排數組

?
1
[6 2 4 1 5 9]

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

?
1
[6 2 4 1 5 9]

交換后變成

?
1
[2 6 1 4 5 9]

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

?
1
[2 6 1 4 5 9]

交換后變成

?
1
[2 1 6 4 5 9]

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

?
1
[2 1 6 4 5 9]

交換后

?
1
[1 2 4 6 5 9]

第四趟偶數列

?
1
[1 2 4 6 5 9]

一次交換

?
1
[1 2 4 5 6 9]

Java實現:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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,則不再整體循環了。跟冒泡排序一樣,可以減少最后一次內層循環。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99pao在线视频精品免费 | 欧美一级乱妇老太婆特黄 | 天天插综合网 | 免费在线视频成人 | 香蕉eeww99国产精选播放 | 黑人艹 | 91精品综合久久久久m3u8 | 我和么公的秘密小说免费 | 无遮挡h肉动漫高清在线 | 国产精品久久久久久久久久久搜索 | 双性肉文h | 日本中文字幕在线精品 | 久见久热 这里只有精品 | 艹艹逼| 色偷偷91久久综合噜噜噜 | zozo日本另类极品 | 日本五十路六十30人8时间 | 日本免费久久久久久久网站 | 天天有好逼 | 国产亚洲欧美日韩综合综合二区 | 青春草在线观看视频 | 亚洲精品免费在线 | 亚洲国产精品日本无码网站 | 和老外3p爽粗大免费视频 | 免费一级毛片在线播放放视频 | 久久无码AV亚洲精品色午夜麻豆 | 女同久久另类99精品国产 | 毛片在线免费视频 | 国产盗摄wc女厕所 | 99草 | 欧美破处女视频 | 欧美一级特黄特色大片 | 欧美调教打屁股spank视频 | 亚洲乱亚洲乱妇41p国产成人 | 欧美日韩精品一区二区三区视频在线 | 成年人视频在线免费看 | 韩剧消失的眼角膜免费完整版 | 99色亚洲| 久久国产免费 | 热久久最新视频 | 国产男女性特黄录像 |