手机
当前位置:查字典教程网 >编程开发 >Java >数组重排序(如何将所有奇数都放在所有偶数前面)的深入分析
数组重排序(如何将所有奇数都放在所有偶数前面)的深入分析
摘要:这里介绍一种高效的能在O(n)时间复杂度内完成的算法。核心思想是:定义两个指针,一个指针A从前往后扫描,一个指针B从后往前扫描。指针A扫描到...

这里介绍一种高效的能在O(n)时间复杂度内完成的算法。

核心思想是:定义两个指针,一个指针A从前往后扫描,一个指针B从后往前扫描。指针A扫描到偶数暂停,指针B扫描到奇数暂停,然后交换着两个数,交换之后继续如上述扫描和交换,直到指针A和指针B重合停止。

这个算法的Java代码如下:

复制代码 代码如下:

package Reorder;

public class Reorder {

public static void main(String[] args) {

int[] list = { 1, 2, 3, 4, 5, 7, 9, 11 };

reorderOddEven(list);

}

public static void reorderOddEven(int[] list) {

int length = list.length;

for (int i = 0; i < length; i++) {

System.out.print(list[i] + " ");

}

System.out.print("n");

int begin = 0;

int end = length - 1;

while (begin < end) {

while (begin < end && (list[begin] & 0x1) != 0)

begin++;

while (begin < end && (list[end] & 0x1) == 0)

end--;

if (begin < end) {

int temp = list[begin];

list[begin] = list[end];

list[end] = temp;

}

}

for (int i = 0; i < length; i++) {

System.out.print(list[i] + " ");

}

}

}

【数组重排序(如何将所有奇数都放在所有偶数前面)的深入分析】相关文章:

java去除集合中重复元素示例分享 java去除重复

基于Java HashMap的死循环的启示详解

通过java备份恢复mysql数据库的实现代码

Java硬币翻转倍数递增试算实例

基于java内部类作用的深入分析

基于JavaCore文件的深入分析

Java中用户向系统传递参数的三种基本方式实例分享

java中的Io(input与output)操作总结(二)

java中子类继承父类,程序运行顺序的深入分析

基于jni调用时,jvm报错问题的深入分析

精品推荐
分类导航