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

网友投稿 191 2023-07-19


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

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

举例吧,

待排数组

[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 5rXERaYPuBx 9]

交换后

[1 2 4 6 5 9]

第四趟偶数列

[1 2 4 6 5 9]

一次交换

[1 2 4 5 6 9]

JavrXERaYPuBxa实现:

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]);

erXERaYPuBxven = true;

}

}

flag = odd || even; //若为false,表示不论奇偶序列,一个符合条件的比较都没有

}

}

上面的 flag = odd || even;    有一个为true,表示还在交换, 那么最后只有 都为 false时,flag才为false。

改写成 flag = odd && even;    有一个为false,则不再整体循环了。跟冒泡排序一样,可以减少最后一次内层循环。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java数组模拟优先级队列数据结构的实例
下一篇:java实现Base64加密解密算法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~