调整数组使奇数全部都位于偶数前面
编程思路:
1、定义要操作的数组;
2、定义i从前往后遍历这个数组,定义j从后往前遍历这个数组;
3、当前arr[i]为偶数而arr[j]为奇数时交换两个元素的位置,否则i++,j–;类似于快速排序;
4、打印操作后的结果。
具体代码如下:
#include <stdio.h>
int main() {
int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
int i = 0, j = 9;
int tmp;
while (arr[i++] % 2 && i < 10);
while (arr[j--] % 2 == 0 && j >= 0);
while (i <= j) {
tmp = arr[i - 1];
arr[i - 1] = arr[j + 1];
arr[j + 1] = tmp;
while (arr[i++] % 2);
while (arr[j--] % 2 == 0);
}
for (i = 0; i < 10; i++) {
printf("%d ", arr[i]);
}
system("pause");
return 0;
}