data:image/s3,"s3://crabby-images/cb7a1/cb7a19ee28b0833a8054c2de296ccba1f48bea63" alt=""
class Solution(object):
def nextPermutation(self, nums):
"""
:type nums: List[int]
:rtype: None Do not return anything, modify nums in-place instead.
"""
i = j = len(nums) - 1
while i > 0 and nums[i - 1] >= nums[i]:
i -= 1
if i == 0: # nums are in descending order
nums.reverse()
return
k = i - 1 # find the last "ascending" position
while nums[j] <= nums[k]:
j -= 1
nums[k], nums[j] = nums[j], nums[k]
l, r = k + 1, len(nums) - 1 # reverse the second part
while l < r:
nums[l], nums[r] = nums[r], nums[l]
l += 1
r -= 1