返回介绍

solution / 2100-2199 / 2164.Sort Even and Odd Indices Independently / README

发布于 2024-06-17 01:03:09 字数 4034 浏览 0 评论 0 收藏 0

2164. 对奇偶下标分别排序

English Version

题目描述

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

  1. 非递增 顺序排列 nums 奇数下标 上的所有值。
    • 举个例子,如果排序前 nums = [4,_1_,2,_3_] ,对奇数下标的值排序后变为 [4,_3_,2,_1_] 。奇数下标 13 的值按照非递增顺序重排。
  2. 非递减 顺序排列 nums 偶数下标 上的所有值。
    • 举个例子,如果排序前 nums = [_4_,1,_2_,3] ,对偶数下标的值排序后变为 [_2_,1,_4_,3] 。偶数下标 02 的值按照非递减顺序重排。

返回重排 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

解法

方法一

class Solution:
  def sortEvenOdd(self, nums: List[int]) -> List[int]:
    a = sorted(nums[::2])
    b = sorted(nums[1::2], reverse=True)
    nums[::2] = a
    nums[1::2] = b
    return nums
class Solution {
  public int[] sortEvenOdd(int[] nums) {
    int n = nums.length;
    int[] a = new int[(n + 1) >> 1];
    int[] b = new int[n >> 1];
    for (int i = 0, j = 0; j < n >> 1; i += 2, ++j) {
      a[j] = nums[i];
      b[j] = nums[i + 1];
    }
    if (n % 2 == 1) {
      a[a.length - 1] = nums[n - 1];
    }
    Arrays.sort(a);
    Arrays.sort(b);
    int[] ans = new int[n];
    for (int i = 0, j = 0; j < a.length; i += 2, ++j) {
      ans[i] = a[j];
    }
    for (int i = 1, j = b.length - 1; j >= 0; i += 2, --j) {
      ans[i] = b[j];
    }
    return ans;
  }
}
class Solution {
public:
  vector<int> sortEvenOdd(vector<int>& nums) {
    int n = nums.size();
    vector<int> a;
    vector<int> b;
    for (int i = 0; i < n; ++i) {
      if (i % 2 == 0)
        a.push_back(nums[i]);
      else
        b.push_back(nums[i]);
    }
    sort(a.begin(), a.end());
    sort(b.begin(), b.end(), greater<int>());
    vector<int> ans(n);
    for (int i = 0, j = 0; j < a.size(); i += 2, ++j) ans[i] = a[j];
    for (int i = 1, j = 0; j < b.size(); i += 2, ++j) ans[i] = b[j];
    return ans;
  }
};
func sortEvenOdd(nums []int) []int {
  n := len(nums)
  var a []int
  var b []int
  for i, v := range nums {
    if i%2 == 0 {
      a = append(a, v)
    } else {
      b = append(b, v)
    }
  }
  ans := make([]int, n)
  sort.Ints(a)
  sort.Slice(b, func(i, j int) bool {
    return b[i] > b[j]
  })
  for i, j := 0, 0; j < len(a); i, j = i+2, j+1 {
    ans[i] = a[j]
  }
  for i, j := 1, 0; j < len(b); i, j = i+2, j+1 {
    ans[i] = b[j]
  }
  return ans
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文