LeetCode 905. 按奇偶排序数组

45 篇文章 1 订阅
24 篇文章 0 订阅

905. 按奇偶排序数组

题目链接

给定一个非负整数数组 A,返回一个由 A 的所有偶数元素组成的数组,后面跟 A 的所有奇数元素。

你可以返回满足此条件的任何数组作为答案。
示例:
输入:[3,1,2,4]
输出:[2,4,3,1]
输出 [4,2,3,1],[2,4,1,3] 和 [4,2,1,3] 也会被接受。

解题思路:这里将判断是否为偶数改为了「&」(与运算),当计算数据量过大时「&」运算比求余运算的效率更高,更节省内存
同时将奇数和偶数分别用两个变量标记,偶数则按题要求从前往后放入数组,奇数则从后往前放入数组。用前缀表达式节省了一个变量

int* sortArrayByParity(int* A, int ASize, int* returnSize) {
	*returnSize = 0;
	int i = 0,k=ASize,*newA=(int *)malloc(ASize*sizeof(int));
	for (; i < ASize; i++)
		if ((A[i] &1) == 0)
			newA[(*returnSize)++] = A[i];
		else
			newA[--k] = A[i];
	(*returnSize) = ASize;
	return newA;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值