Leetcode 922. 按奇偶排序数组 II

给定一个非负整数数组 nums,  nums 中一半整数是 奇数 ,一半整数是 偶数 。

对数组进行排序,以便当 nums[i] 为奇数时,i 也是 奇数 ;当 nums[i] 为偶数时, i 也是 偶数 。

你可以返回 任何满足上述条件的数组作为答案 。

示例 1:

输入:nums = [4,2,5,7]
输出:[4,5,2,7]
解释:[4,7,2,5],[2,5,4,7],[2,7,4,5] 也会被接受。

示例 2:

输入:nums = [2,3]
输出:[2,3]

提示:

  • 2 <= nums.length <= 2 * 10^4
  • nums.length 是偶数
  • nums 中一半是偶数
  • 0 <= nums[i] <= 1000

 题目意思就是将一个整数数组按照偶数和奇数排序,使得偶数索引处填充偶数,奇数索引处填充奇数

步骤:

  1. 定义两个vector<int>向量evenodd用来分别存储偶数和奇数,大小都是原数组A大小的一半(因为假设数组A中偶数和奇数的数量相等)。

  2. 定义另一个vector<int>向量result,用来存储最终的结果,大小与原数组A相同。

  3. 初始化三个索引变量evenIndexoddIndexresultIndex,分别用于跟踪even数组、odd数组和result数组的当前位置。

  4. 遍历数组A中的每个元素,根据元素的奇偶性将其放入evenodd数组中。如果A[i]是偶数,则放入even数组并递增evenIndex;如果是奇数,则放入odd数组并递增oddIndex

  5. 遍历evenodd数组,按顺序将元素交替放入result数组中,即首先放入even[i],然后放入odd[i],并在每次放入后递增resultIndex

  6. 最后返回result数组,此时result数组中的元素按照题目要求的偶数索引放偶数、奇数索引放奇数的方式排列。

#include <vector>
using namespace std;

class Solution {
public:
    // 函数sortArrayByParityII接收一个整数类型的vector引用A,返回一个vector<int>
    vector<int> sortArrayByParityII(vector<int>& A) {
        // 创建一个vector来存放偶数,大小是输入数组A的一半
        vector<int> even(A.size() / 2);
        // 创建一个vector来存放奇数,大小也是输入数组A的一半
        vector<int> odd(A.size() / 2);
        // 创建一个vector来存放最终的结果,大小与输入数组A相同
        vector<int> result(A.size());
        // evenIndex用来追踪even数组的当前索引
        int evenIndex = 0;
        // oddIndex用来追踪odd数组的当前索引
        int oddIndex = 0;
        // resultIndex用来追踪result数组的当前索引
        int resultIndex = 0;
        // 遍历输入数组A,根据每个元素的奇偶性分别存入even或odd数组
        for (int i = 0; i < A.size(); i++) {
            if (A[i] % 2 == 0) // 如果A[i]是偶数
                even[evenIndex++] = A[i]; // 存入even数组,并增加evenIndex
            else // 否则
                odd[oddIndex++] = A[i]; // 存入odd数组,并增加oddIndex
        }
        // 交替地从even和odd数组中取出元素存入result数组
        for (int i = 0; i < evenIndex; i++) {
            result[resultIndex++] = even[i]; // 存入一个偶数
            result[resultIndex++] = odd[i];  // 紧接着存入一个奇数
        }
        // 返回最终排序好的数组
        return result;
    }
};

参考文章:代码随想录 (programmercarl.com)

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值