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

1. 题目描述——调整奇数偶数顺序

调整数组使奇数全部都位于偶数前面。

题目:
输入一个整数数组,实现一个函数,来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分,所有偶数位于数组的后半部分。

2.思路

思路:设置两个变量,一个从前往后遍历,一个从后往前遍历。
前面判断是否是奇数,是奇数就++,目的是找偶数
后面判断是否是偶数,是偶数就–,
然后前面的偶数和后面的奇数交换。

3.代码实现1

这个版本是有问题的,就是当我们第一次循环进去,left++和right–它是会一直循环下去,我们需要在里面也加上(left<right)判断到交互的地方就不能再让它继续++和–了。会数组越界。

//调整奇数偶数顺序
//思路:设置两个变量,一个从前往后遍历,一个从后往前遍历。
//前面判断是否是偶数,
//后面发现是否有奇数,
//然后交换。
#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

//调整奇数偶数顺序
//思路:设置两个变量,一个从前往后遍历,一个从后往前遍历。
//前面判断是否是偶数,
//后面发现是否有奇数,
//然后交换。
#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;
}
//
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值