算法--对奇偶下标分别排序

252 阅读2分钟

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第8天,点击查看活动详情

题目

leetcode 2164. 对奇偶下标分别排序

给你一个下标从 0 开始的整数数组 nums 。根据下述规则重排 nums 中的值:

按 非递增 顺序排列 nums 奇数下标 上的所有值。 举个例子,如果排序前 nums = [4,1,2,3] ,对奇数下标的值排序后变为 [4,3,2,1] 。奇数下标 1 和 3 的值按照非递增顺序重排。 按 非递减 顺序排列 nums 偶数下标 上的所有值。 举个例子,如果排序前 nums = [4,1,2,3] ,对偶数下标的值排序后变为 [2,1,4,3] 。偶数下标 0 和 2 的值按照非递减顺序重排。 返回重排 nums 的值之后形成的数组。

 

示例 1:

输入:nums = [4,1,2,3]
输出:[2,3,4,1]
解释:
首先,按非递增顺序重排奇数下标(1 和 3)的值。
所以,nums 从 [4,1,2,3] 变为 [4,3,2,1] 。
然后,按非递减顺序重排偶数下标(0 和 2)的值。
所以,nums 从 [4,1,2,3] 变为 [2,3,4,1] 。
因此,重排之后形成的数组是 [2,3,4,1]

示例 2:

输入:nums = [2,1]
输出:[2,1]
解释:
由于只有一个奇数下标和一个偶数下标,所以不会发生重排。
形成的结果数组是 [2,1] ,和初始数组一样。 

提示:

1 <= nums.length <= 100 1 <= nums[i] <= 100

题解

题目意思已经很简单了,不再过多解释。借题思路是我们创建两个数组分别保存奇数位和偶数位的数字。最后再合并两个数组得到最终答案。

var sortEvenOdd = function(nums) {
    const tem = [[],[]];
    const res = [];
    for(let i = 0, f = true; i < nums.length; i++, f = !f){
        if(f){
            tem[0].push(nums[i])
        }else{
            tem[1].push(nums[i])
        }
    }

    tem[0].sort((a,b)=>a-b)
    tem[1].sort((a,b)=>b-a)
    for (let i = 0; i < tem[0].length || i < tem[1].length; i++) {
        if (tem[0][i] && tem[1][i]) {
            res.push(tem[0][i], tem[1][i]);
        }else if(tem[0][i]){
            res.push(tem[0][i])
        }else{
            res.push(tem[1][i]);
        }
        
    }
    return res
};

代码详解

定义变量tem为储存数组,定义变量res为结果数组。 如果通过奇数偶数下标分别加入到对应数组中。再对这两个数组进行排序,然后再合并两个数组即可。