算法题:奇数在前 偶数在后,相对顺序保持不变

1. 题目:奇数在前 偶数在后,相对顺序保持不变

2. 解决思路:

step: 1 首先找到数组中的第一个奇数放在A[0]
step: 2 之后从该位置的后面一个位置开始查找奇数

3. 源码

#include <stdio.h>
 
void lmf(int A[], int n)
{
    int i, j, temp, lastOdd;
    for (i = 0; i < n; i++)   //找到数组中的第一个奇数放在A[0]
    {
        if (A[i] & 1) 
        {
            temp = A[i];
            for (j = i;j > 0; j--) 
            {
                A[j] = A[j - 1];
            }
            A[0] = temp;                                                                       
            lastOdd = i;   //之后从lastOdd + 1位置开始查找奇数
            break;
        }
    } 
    for (i = lastOdd + 1, lastOdd = 0; i < n; i++)
    {
        if (A[i] & 1)
        {
            temp = A[i];
            for (j = i; j > lastOdd + 1; j--)   //依次向前移动
           {
                A[j] = A[j - 1];
            }
            A[++lastOdd] = temp;
        } 
    }
} 
int main(void)
{
    int A[] = {6, 4, 3, 8, 10, 11, 12, 9};
    int i, n = 8;                                                                              
    lmf(A, n);
    for (i = 0;i < n; i++)
	{
		printf("%d ", A[i]);
	}
    printf("\n");
    return 0;
}
参考资料:https://blog.csdn.net/bxyill/article/details/8644301
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值