给定一个若干整数的排列,给出按正数大小进行字典序从小到大排序后的下一个排列。
如果没有下一个排列,则输出字典序最小的序列。
您在真实的面试中是否遇到过这个题? Yes 样例左边是原始排列,右边是对应的下一个排列。
1,2,3 → 1,3,2
3,2,1 → 1,2,3
1,1,5 → 1,5,1
挑战不允许使用额外的空间。
标签 排列 数组 [java] view plain copy public class Solution { /** * @param nums: an array of integers * @return: return nothing (void), do not return anything, modify nums in-place instead */ public void nextPermutation(int[] nums) { // write your code here int n = nums.length; for(int i=n-1;i>=0;i--) { for(int j=n-1;j>i;j--) { if(nums[i]<nums[j]) { int tmp = nums[i]; nums[i] = nums[j]; nums[j] = tmp; Arrays.sort(nums,i+1,nums.length); return; } } } Arrays.sort(nums); } }