把一个数组的偶数放在最后面,奇数放在前面;
void move_odd_ji(int *arr,int sz)
{
int left = 0;
int right = sz - 1;
while (left < right)
{
//从左向有判断奇数
while ((left<right) &&arr[left] % 2 == 1)
{
left++;
}
//从右向左判断偶数
while ((left < right) && arr[right] % 2 == 0)
{
right--;
}
//进行交换
if (left < right)
{
int temp = arr[left];
arr[left] = arr[right];
arr[right] = temp;
left++;
right--;
}
}
}
int main()
{
int arr[10];
int i = 0;
//输入
int sz = sizeof(arr) / sizeof(arr[0]);
for (i = 0; i < 10; i++)
{
scanf("%d", &arr[i]);
}
//调整
move_odd_ji(arr, sz);
//输出
for (i = 0; i < 10; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
把一个数组的偶数放在最后面,奇数放在前面;
最新推荐文章于 2024-07-15 22:10:26 发布