如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。
必须原地修改,只允许使用额外常数空间。
以下是一些例子,输入位于左侧列,其相应输出位于右侧列。...为了保证不同排列符合题目的顺序,在生成所有组合之前,先进行升序排序,然后再进行排列。–但是这种情况,时间复杂度太高,而且不满足题目要求的空间复杂度要求。...比如,对于数组1,2,3,4,5,下一个排列应该是1,2,3,5,4,下一个应该是1,2,4,3,5.变动的情况先发生在末尾,在以1,2,3,4之后只有一个5,下一个排列,应该保持1,2,3不动,整体变成...1,2,3,5,4;
从后往前,先找到第一个不是降序排序的数字的下标;
如果下标的升序排序结果;
如果不为0,在这个元素之后找到第一个比它大的数字的下标,两者交换...,对后续子数组做升序排序即可。