數組重排序(若何將一切奇數都放在一切偶數後面)的深刻剖析。本站提示廣大學習愛好者:(數組重排序(若何將一切奇數都放在一切偶數後面)的深刻剖析)文章只能為提供參考,不一定能成為您想要的結果。以下是數組重排序(若何將一切奇數都放在一切偶數後面)的深刻剖析正文
這裡引見一種高效的能在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] + " ");
}
}
}