1. 题目描述------调整奇数偶数顺序
调整数组使奇数全部都位于偶数前面。
题目:
输入一个整数数组,实现一个函数,来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分,所有偶数位于数组的后半部分。
2.思路
思路:设置两个变量,一个从前往后遍历,一个从后往前遍历。
前面判断是否是奇数,是奇数就++,目的是找偶数
后面判断是否是偶数,是偶数就--,
然后前面的偶数和后面的奇数交换。
3.代码实现1
这个版本是有问题的,就是当我们第一次循环进去,left++和right--它是会一直循环下去,我们需要在里面也加上(left<right)判断到交互的地方就不能再让它继续++和--了。会数组越界。
c
//调整奇数偶数顺序
//思路:设置两个变量,一个从前往后遍历,一个从后往前遍历。
//前面判断是否是偶数,
//后面发现是否有奇数,
//然后交换。
#include<stdio.h>
void adjust(int arr[], int size)
{
int left = 0;
int right = size - 1;
int i = 0;
for (i = 0; i < size; i++)
{
while (left < right)
{
//判断是奇数,就下一个,在找偶数
if (arr[left] % 2 == 1)
{
left++;
}
//判断是偶数,就下一个,在找奇数
if (arr[right] % 2 == 0)
{
right--;
}
if(left < right)
{
int tem = arr[left];
arr[left] = arr[right];
arr[right] = tem;
left++;
right--;
}
}
}
}
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int sz = sizeof(arr) / sizeof(arr[0]);
adjust(arr, sz);
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
4.代码实现2
c
//调整奇数偶数顺序
//思路:设置两个变量,一个从前往后遍历,一个从后往前遍历。
//前面判断是否是偶数,
//后面发现是否有奇数,
//然后交换。
#include<stdio.h>
void adjust(int arr[], int size)
{
int left = 0;
int right = size - 1;
int i = 0;
for (i = 0; i < size; i++)
{
while (left < right)
{
//判断是奇数,就直接下一个,在找偶数
if ((left<right)&&(arr[left] % 2 == 1))
{
left++;
}
//判断是偶数,就直接下一个,在找奇数
if ((left < right) && (arr[right] % 2 == 0))
{
right--;
}
if(left < right)//前面的偶数和后面的奇数交换
{
int tem = arr[left];
arr[left] = arr[right];
arr[right] = tem;
left++;
right--;
}
}
}
}
int main()
{
int arr[] = { 1,3,5,7,9,11,13,15 };
int sz = sizeof(arr) / sizeof(arr[0]);
adjust(arr, sz);
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
//