leecode 31.下一个排列(Golang)

题目:

整数数组的 下一个排列 是指其整数的下一个字典序更大的排列。更正式地,如果数组的所有排列根据其字典顺序从小到大排列在一个容器中,那么数组的 下一个排列 就是在这个有序容器中排在它后面的那个排列。如果不存在下一个更大的排列,那么这个数组必须重排为字典序最小的排列(即,其元素按升序排列)。

如何解决题目:

主要实现目标可以拆分为几点:

1.比之前要大

2.在比之前要大的基础上 ,要最小的那个

3.如果没有比之前更大的了, 比如 3->2->1 这样的倒序序列,则整体反转

实现步骤:

1.从后向前 查找第一个 相邻升序 的元素对 (i,j),满足 A[i] < A[j]。此时 [j,end) 必然是降序

2.在 [j,end) 从后向前 查找第一个满足 A[i] < A[k] 的 k。A[i]、A[k] 分别就是上文所说的「小数」、「大数」

3.将 A[i] 与 A[k] 交换 //将最小的数 放到前面

4.可以断定这时 [j,end) 必然是降序,逆置 [j,end),使其升序 //换的那个数 还是小于换之前的,所以依然是降序,要更小一点,所以反转

5.如果在步骤 1 找不到符合的相邻元素对,说明当前 [begin,end) 为一个降序顺序,则直接跳到步骤1

三、具体代码

Go 复制代码
func nextPermutation(nums []int) []int {

	length := len(nums)
	right := length - 1
	left := 0

	flag := false // 用来看是否找到了右边比左边大的值
	for right > left {

		if nums[right] > nums[right-1] { //低位的数字   大于高位的了,也就是找到了

			flag = true
			//从右开始找到第一个大于right-1的 , 也就是找到最小的比    right-1大的值, 交换,交换完  右边还是降序,因为找的是第一个

			for i := length - 1; i >= right; i-- {
				if nums[i] > nums[right-1] {
					nums[i], nums[right-1] = nums[right-1], nums[i]
					break
				}
			}

			reverse(nums, right, length-1)
			break
		}
		right--

	}

	if !flag {
		reverse(nums, 0, length-1)
	}

	return nums

}

func reverse(nums []int, start, end int) {

	for start < end {
		nums[start], nums[end] = nums[end], nums[start]
		start++
		end--
	}

}
相关推荐
dazzle2 小时前
机器学习算法原理与实践-入门(十一):基于PyTorch的房价预测实战
pytorch·算法·机器学习
袋鼠云数栈9 小时前
集团数字化统战实战:统一数据门户与全业态监管体系构建
大数据·数据结构·人工智能·多模态
小月球~9 小时前
天梯赛 · 并查集
数据结构·算法
仍然.10 小时前
算法题目---模拟
java·javascript·算法
三道渊11 小时前
C语言:文件I/O
c语言·开发语言·数据结构·c++
kali-Myon12 小时前
CTFshow-Pwn142-Off-by-One(堆块重叠)
c语言·数据结构·安全·gdb·pwn·ctf·
潇冉沐晴12 小时前
DP——背包DP
算法·背包dp
GIOTTO情12 小时前
2026 世界互联网大会亚太峰会|AI 时代媒介投放的技术实战与算法优化
人工智能·算法
逆境不可逃13 小时前
LeetCode 热题 100 之 543. 二叉树的直径 102. 二叉树的层序遍历 108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
算法·leetcode·职场和发展
计算机安禾13 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio