31:下一个排列

This commit is contained in:
huangge1199 2021-07-15 14:28:20 +08:00
parent 6f932d5980
commit fddfc74b0e
2 changed files with 141 additions and 0 deletions

View File

@ -0,0 +1,96 @@
//实现获取 下一个排列 的函数算法需要将给定数字序列重新排列成字典序中下一个更大的排列
//
// 如果不存在下一个更大的排列则将数字重新排列成最小的排列即升序排列
//
// 必须 原地 修改只允许使用额外常数空间
//
//
//
// 示例 1
//
//
//输入nums = [1,2,3]
//输出[1,3,2]
//
//
// 示例 2
//
//
//输入nums = [3,2,1]
//输出[1,2,3]
//
//
// 示例 3
//
//
//输入nums = [1,1,5]
//输出[1,5,1]
//
//
// 示例 4
//
//
//输入nums = [1]
//输出[1]
//
//
//
//
// 提示
//
//
// 1 <= nums.length <= 100
// 0 <= nums[i] <= 100
//
// Related Topics 数组 双指针
// 👍 1221 👎 0
package leetcode.editor.cn;
//31:下一个排列
public class NextPermutation {
public static void main(String[] args) {
//测试代码
Solution solution = new NextPermutation().new Solution();
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public void nextPermutation(int[] nums) {
if (nums.length < 2) {
return;
}
int i = nums.length - 2;
for (; i >= 0; i--) {
if (nums[i] < nums[i + 1]) {
break;
}
}
if (i != -1) {
int j = i + 1;
for (; j < nums.length; j++) {
if (nums[j] <= nums[i]) {
break;
}
}
swap(nums, i, j - 1);
}
int start = i + 1;
int end = nums.length - 1;
while (start < end) {
swap(nums, start, end);
start++;
end--;
}
}
private void swap(int[] nums, int i, int j) {
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
}
}
//leetcode submit region end(Prohibit modification and deletion)
}

View File

@ -0,0 +1,45 @@
<p>实现获取 <strong>下一个排列</strong> 的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。</p>
<p>如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。</p>
<p>必须<strong><a href="https://baike.baidu.com/item/%E5%8E%9F%E5%9C%B0%E7%AE%97%E6%B3%95" target="_blank"> 原地 </a></strong>修改,只允许使用额外常数空间。</p>
<p> </p>
<p><strong>示例 1</strong></p>
<pre>
<strong>输入:</strong>nums = [1,2,3]
<strong>输出:</strong>[1,3,2]
</pre>
<p><strong>示例 2</strong></p>
<pre>
<strong>输入:</strong>nums = [3,2,1]
<strong>输出:</strong>[1,2,3]
</pre>
<p><strong>示例 3</strong></p>
<pre>
<strong>输入:</strong>nums = [1,1,5]
<strong>输出:</strong>[1,5,1]
</pre>
<p><strong>示例 4</strong></p>
<pre>
<strong>输入:</strong>nums = [1]
<strong>输出:</strong>[1]
</pre>
<p> </p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 <= nums.length <= 100</code></li>
<li><code>0 <= nums[i] <= 100</code></li>
</ul>
<div><div>Related Topics</div><div><li>数组</li><li>双指针</li></div></div>\n<div><li>👍 1221</li><li>👎 0</li></div>