下一个排列

xiaoxiao2021-02-28  33

 下一个排列

 描述 笔记 数据 评测

给定一个若干整数的排列,给出按正数大小进行字典序从小到大排序后的下一个排列。

如果没有下一个排列,则输出字典序最小的序列。

您在真实的面试中是否遇到过这个题?   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);      }  
转载请注明原文地址: https://www.6miu.com/read-2625862.html

最新回复(0)