C语言初阶习题【24】调整奇数偶数顺序

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;
}
//
相关推荐
GalaxyPokemon1 小时前
归并排序:分治思想的高效排序
数据结构·算法·排序算法
ThreeYear_s1 小时前
基于FPGA的PID算法学习———实现PI比例控制算法
学习·算法·fpga开发
我不是加奈3 小时前
QMC5883L的驱动
c语言·驱动开发·单片机·嵌入式硬件
Coding小公仔3 小时前
LeetCode 240 搜索二维矩阵 II
算法·leetcode·矩阵
C++chaofan3 小时前
74. 搜索二维矩阵
java·算法·leetcode·矩阵
青小莫4 小时前
数据结构-C语言-链表OJ
c语言·数据结构·链表
Studying 开龙wu4 小时前
机器学习监督学习实战五:六种算法对声呐回波信号进行分类
学习·算法·机器学习
Mi Manchi264 小时前
力扣热题100之二叉树的层序遍历
python·算法·leetcode
wu~9704 小时前
leetcode:42. 接雨水(秒变简单题)
算法·leetcode·职场和发展