leetcode/2164.Sort-Even-and-Odd-Indices-Independently/README.md
You are given a 0-indexed integer array nums. Rearrange the values of nums according to the following rules:
nums in non-increasing order.
nums = [4,**1**,2,**3**] before this step, it becomes [4,**3**,2,**1**] after. The values at odd indices 1 and 3 are sorted in non-increasing order.nums in non-decreasing order.
nums = [**4**,1,**2**,3] before this step, it becomes [**2**,1,**4**,3] after. The values at even indices 0 and 2 are sorted in non-decreasing order.Return the array formed after rearranging the values of nums.
Example 1:
Input: nums = [4,1,2,3]
Output: [2,3,4,1]
Explanation:
First, we sort the values present at odd indices (1 and 3) in non-increasing order.
So, nums changes from [4,1,2,3] to [4,3,2,1].
Next, we sort the values present at even indices (0 and 2) in non-decreasing order.
So, nums changes from [4,1,2,3] to [2,3,4,1].
Thus, the array formed after rearranging the values is [2,3,4,1].
Example 2:
Input: nums = [2,1]
Output: [2,1]
Explanation:
Since there is exactly one odd index and one even index, no rearrangement of values takes place.
The resultant array formed is [2,1], which is the same as the initial array.
Constraints:
1 <= nums.length <= 1001 <= nums[i] <= 100给你一个下标从 0 开始的整数数组 nums 。根据下述规则重排 nums 中的值:
返回重排 nums 的值之后形成的数组。
package leetcode
import (
"sort"
)
func sortEvenOdd(nums []int) []int {
odd, even, res := []int{}, []int{}, []int{}
for index, v := range nums {
if index%2 == 0 {
even = append(even, v)
} else {
odd = append(odd, v)
}
}
sort.Ints(even)
sort.Sort(sort.Reverse(sort.IntSlice(odd)))
indexO, indexE := 0, 0
for i := 0; i < len(nums); i++ {
if i%2 == 0 {
res = append(res, even[indexE])
indexE++
} else {
res = append(res, odd[indexO])
indexO++
}
}
return res
}