Nicn的刷题日常之调整奇数偶数顺序

目录

1.题目描述

2.解题思路

3.解题


1.题目描述

输入一个整数数组,实现一个函数,

来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分,

所有偶数位于数组的后半部分。

2.解题思路

复制代码
1. 给定两个下标left和right,left放在数组的起始位置,right放在数组中最后一个元素的位置
2. 循环进行一下操作
 a. 如果left和right表示的区间[left, right]有效,进行b,否则结束循环
 b. left从前往后找,找到一个偶数后停止
 c. right从后往前找,找到一个奇数后停止
 d. 如果left和right都找到了对应的数据,则交换,继续a,

3.解题

cpp 复制代码
void swap_arr(int arr[], int sz)
{
	int left = 0;
	int right = sz-1;
	int tmp = 0;


	while(left<right)
	{
     // 从前往后,找到一个偶数,找到后停止
		while((left<right)&&(arr[left]%2==1))
		{
			left++;
		}
     
		// 从后往前找,找一个奇数,找到后停止
		while((left<right)&& (arr[right]%2==0))
		{
			right--;
		}
     
     // 如果偶数和奇数都找到,交换这两个数据的位置
     // 然后继续找,直到两个指针相遇
		if(left<right)
		{
			tmp = arr[left];
			arr[left] = arr[right];
			arr[right] = tmp;
		}
	}
}
相关推荐
wen__xvn2 分钟前
基础算法集训第03天:递推
算法
wen__xvn7 分钟前
算法基础集训第19天:广度优先搜索
算法·宽度优先
这就是佬们吗10 分钟前
力扣---leetcode48
java·笔记·后端·算法·leetcode·idea
薛不痒25 分钟前
项目:矿物分类(训练模型)
开发语言·人工智能·python·学习·算法·机器学习·分类
被星1砸昏头28 分钟前
C++与Node.js集成
开发语言·c++·算法
程序员zgh32 分钟前
C++ 纯虚函数 — 抽象接口
c语言·开发语言·c++·经验分享·笔记·接口隔离原则
MicroTech202540 分钟前
微算法科技(NASDAQ :MLGO)开发基于QML的入侵检测识别系统(QML-IDS),强化网络安全防护
科技·算法·web安全
SR_shuiyunjian42 分钟前
Python第一次作业
开发语言·python·算法
期末考复习中,蓝桥杯都没时间学了1 小时前
力扣刷题记录3
算法·leetcode·职场和发展