在路上

 找回密码
 立即注册
在路上 站点首页 学习 查看内容

简单讲解奇偶排序算法及在Java数组中的实现

2016-7-29 15:37| 发布者: zhangjf| 查看: 630| 评论: 0

摘要: 奇偶排序是一个比较有个性的排序,基本思路是奇数列排一趟序,偶数列排一趟序,再奇数排,再偶数排,直到全部有序 举例吧, 待排数组 复制代码 第一次比较奇数列,奇数列与它的邻居偶数列比较,如6和2比,4和1比,5和9比 复制 ...

奇偶排序是一个比较有个性的排序,基本思路是奇数列排一趟序,偶数列排一趟序,再奇数排,再偶数排,直到全部有序

举例吧,

待排数组

  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. static void oddEvensort(int[] ary) {
  2. //奇偶排序
  3. boolean flag = true;
  4. while (flag) {
  5. boolean odd = false, even = false;
  6. for (int i = 0; i < ary.length - 1; i+=2) {
  7. if (ary[i] > ary[i + 1]) {
  8. ary[i] = ary[i + 1] + 0 * (ary[i + 1] = ary[i]);
  9. odd = true;
  10. }
  11. }
  12. for (int i = 1; i < ary.length - 1; i+=2) {
  13. if (ary[i] > ary[i + 1]) {
  14. ary[i] = ary[i + 1] + 0 * (ary[i + 1] = ary[i]);
  15. even = true;
  16. }
  17. }
  18. flag = odd || even; //若为false,表示不论奇偶序列,一个符合条件的比较都没有
  19. }
  20. }
复制代码

上面的 flag = odd || even; 有一个为true,表示还在交换, 那么最后只有 都为 false时,flag才为false。
改写成 flag = odd && even; 有一个为false,则不再整体循环了。跟冒泡排序一样,可以减少最后一次内层循环。

最新评论

小黑屋|在路上 ( 蜀ICP备15035742号-1 

;

GMT+8, 2025-5-6 09:46

Copyright 2015-2025 djqfx

返回顶部