下一个排列
题目
给定一个若干整数的排列,给出按正数大小进行字典序从小到大排序后的下一个排列。
如果没有下一个排列,则输出字典序最小的序列。样例
左边是原始排列,右边是对应的下一个排列。
1,2,3 → 1,3,2
3,2,1 → 1,2,3
1,1,5 → 1,5,1挑战
不允许使用额外的空间。
题解
字典排序法。参见52.Next Permutation-下一个排列(中等题)
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) {
int n = nums.length;
if (n > 1)
{
for(int i=n-2;i>=0;i--)
{
if (nums[i] < nums[i+1])
{
for (int j=n-1;j>i;j--)
{
if (nums[j] > nums[i])
{
swap(nums,i,j);
reverse(nums,i+1,nums.length-1);
return;
}
}
}
}
}
reverse(nums,0,nums.length-1);
}
private void swap(int[] nums,int i,int j)
{
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
}
private void reverse(int[] nums,int start,int end)
{
for (int i=start,j=end;i<j;i++,j--)
{
swap(nums,i,j);
}
}
}
Last Update 2016.10.28