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;
}
//
相关推荐
MMjeaty19 分钟前
数据结构——栈和队列
数据结构·算法
瓜瓜怪兽亚23 分钟前
前端基础知识---10 Node.js(三)
数据结构·数据库·node.js
机器学习之心5 小时前
多目标鲸鱼优化算法(NSWOA),含46种测试函数和9个评价指标,MATLAB实现
算法·matlab·多目标鲸鱼优化算法·46种测试函数·9个评价指标
古译汉书6 小时前
嵌入式铁头山羊STM32-各章节详细笔记-查阅传送门
数据结构·笔记·stm32·单片机·嵌入式硬件·个人开发
max5006006 小时前
基于Meta Llama的二语习得学习者行为预测计算模型
人工智能·算法·机器学习·分类·数据挖掘·llama
超级大福宝6 小时前
使用 LLVM 16.0.4 编译 MiBench 中的 patricia遇到的 rpc 库问题
c语言·c++
橘颂TA7 小时前
【数据结构】解锁数据结构:通往高效编程的密钥
数据结构
王哥儿聊AI7 小时前
Lynx:新一代个性化视频生成模型,单图即可生成视频,重新定义身份一致性与视觉质量
人工智能·算法·安全·机器学习·音视频·软件工程
手握风云-9 小时前
优选算法的寻踪契合:字符串专题
算法
闭着眼睛学算法9 小时前
【华为OD机考正在更新】2025年双机位A卷真题【完全原创题解 | 详细考点分类 | 不断更新题目 | 六种主流语言Py+Java+Cpp+C+Js+Go】
java·c语言·javascript·c++·python·算法·华为od