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;
}
//
相关推荐
AI小老六16 分钟前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize2 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考15 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营18 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队18 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK2 天前
线段树维护区间 k 次方和
c++·数学·算法·stl