携手创作,共同成长!这是我参与「掘金日新计划 · 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为结果数组。 如果通过奇数偶数下标分别加入到对应数组中。再对这两个数组进行排序,然后再合并两个数组即可。