题目链接:
题目描述:
实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。
如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。
必须原地修改,只允许使用额外常数空间。
以下是一些例子,输入位于左侧列,其相应输出位于右侧列。
1,2,3 → 1,3,2
3,2,1 → 1,2,3
1,1,5 → 1,5,1
解题思路:
1.从后向前找到第一个i<i+1的位置
2.将i后面的数字升序排列
3,将i与后面第一个比其大的数字进行交换
class Solution:
def nextPermutation(self, nums: List[int]) -> None:
"""
Do not return anything, modify nums in-place instead.
"""
if len(nums)>=2:
flag=0
#倒序找到第一个比后面数字小的位置
for i in range(len(nums)-1,0,-1):
if nums[i]>nums[i-1]:
flag=1
#对后面进行排序
nums[i:]=sorted(nums[i:])