LeetCode(31) 下乙個排列

2022-05-07 08:36:10 字數 1120 閱讀 9336

medium!

題目描述:

(請仔細讀題)

實現獲取下乙個排列的函式,演算法需要將給定數字序列重新排列成字典序中下乙個更大的排列。

如果不存在下乙個更大的排列,則將數字重新排列成最小的排列(即公升序排列)。

必須原地修改,只允許使用額外常數空間。

以下是一些例子,輸入位於左側列,其相應輸出位於右側列。

1,2,31,3,2

3,2,11,2,3

1,1,51,5,1

解題思路:

1  2  7  4  3  1

1  3  1  2  4  7

那麼是如何得到的呢,我們通過觀察原陣列可以發現,如果從末尾往前看,數字逐漸變大,到了2時才減小的,然後我們再從後往前找第乙個比2大的數字,是3,那麼我們交換2和3,再把此時3後面的所有數字轉置一下即可,步驟如下:

1  2  7  4  3  1

1  2  7  4  3  1

1  3  7  4  2  1

1  3  1  2  4  7

c++解法一:

1

class

solution

10swap(num[i], num[j]);

11 reverse(num.begin() + i + 1

, num.end());

12return;13

}14}15

reverse(num.begin(), num.end());16}

17 };

下面這種寫法更簡潔一些,但是整體思路和上面的解法沒有什麼區別。

c++解法二:

1

class

solution

9 reverse(nums.begin() + i + 1

, nums.end());10}

11 };

leetcode 31 下乙個排列

實現獲取下乙個排列的函式,演算法需要將給定數字序列重新排列成字典序中下乙個更大的排列。如果不存在下乙個更大的排列,則將數字重新排列成最小的排列 即公升序排列 必須原地修改,只允許使用額外常數空間。以下是一些例子,輸入位於左側列,其相應輸出位於右側列。1,2,3 1,3,2 3,2,1 1,2,3 1...

leetCode 31 下乙個排列

思路就是找到可以變大的最低位,進一步說,就是找到,nums pos 滿足,存在q使得,q pos 且 nums pos nums q 同時要注意的是,最終的答案要取q的下界。這是因為要找剛剛好比所給數字大的數字,所以我們要使得pos位,增大的盡量小。class solution else if nu...

LeetCode31 下乙個排列

實現獲取下乙個排列的函式,演算法需要將給定數字序列重新排列成字典序中下乙個更大的排列。如果不存在下乙個更大的排列,則將數字重新排列成最小的排列 即公升序排列 必須原地修改,只允許使用額外常數空間。以下是一些例子,輸入位於左側列,其相應輸出位於右側列。1,2,3 1,3,2 3,2,1 1,2,3 1...