mirror of
https://github.com/halfrost/LeetCode-Go.git
synced 2025-07-23 18:10:20 +08:00
44 lines
860 B
Go
44 lines
860 B
Go
package leetcode
|
|
|
|
// 解法一 单调栈
|
|
func nextGreaterElements(nums []int) []int {
|
|
res := make([]int, 0)
|
|
indexes := make([]int, 0)
|
|
for i := 0; i < len(nums); i++ {
|
|
res = append(res, -1)
|
|
}
|
|
for i := 0; i < len(nums)*2; i++ {
|
|
num := nums[i%len(nums)]
|
|
for len(indexes) > 0 && nums[indexes[len(indexes)-1]] < num {
|
|
index := indexes[len(indexes)-1]
|
|
res[index] = num
|
|
indexes = indexes[:len(indexes)-1]
|
|
}
|
|
indexes = append(indexes, i%len(nums))
|
|
}
|
|
return res
|
|
}
|
|
|
|
// 解法二
|
|
func nextGreaterElements1(nums []int) []int {
|
|
if len(nums) == 0 {
|
|
return []int{}
|
|
}
|
|
res := []int{}
|
|
for i := 0; i < len(nums); i++ {
|
|
j, find := (i+1)%len(nums), false
|
|
for j != i {
|
|
if nums[j] > nums[i] {
|
|
find = true
|
|
res = append(res, nums[j])
|
|
break
|
|
}
|
|
j = (j + 1) % len(nums)
|
|
}
|
|
if !find {
|
|
res = append(res, -1)
|
|
}
|
|
}
|
|
return res
|
|
}
|