数组重排序(如何将所有奇数都放在所有偶数前面)的深入分析
程序员文章站
2023-12-15 08:32:34
这里介绍一种高效的能在o(n)时间复杂度内完成的算法。核心思想是:定义两个指针,一个指针a从前往后扫描,一个指针b从后往前扫描。指针a扫描到偶数暂停,指针b扫描到奇数暂停,...
这里介绍一种高效的能在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] + " ");
}
}
}
核心思想是:定义两个指针,一个指针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] + " ");
}
}
}