31 下乙個排列

2021-10-04 11:03:14 字數 784 閱讀 3859

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

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

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

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

1,2,3 → 1,3,2

3,2,1 → 1,2,3

1,1,5 → 1,5,1

題解:最初錯誤的想法,從左到右維護乙個單調遞增的序列,這樣就可以知道每個數左邊第乙個小於它本身的下標;然後,從右向前掃,如果它左邊存在小於它的元素,交換位置(比如 i - n 與 i 交換),並將 i - n 後邊的元素排序。

一交,wa了

樣例 : 5  2  0  2  3  1  0

輸出 : 5  2  1  0  0  2  3

正確 : 5  2  0  3  0  1  2

我知道是臨界值的位置找錯了,於是多次模擬了幾組樣例,想到了:假設某個值為臨界交換值 i,那麼它右邊必然有乙個大於它的值 j,並且 j 值越小越好,思路呼之欲出。

class solution 

flag = true;}}

if(flag)

}if(!flag) sort(nums.begin(),nums.end());

}};

31 下乙個排列

public void nextpermutation int nums 從後向前找到第乙個不滿足逆序的元素 int i nums.length 2 for i 0 nums i nums i 1 i 注意,這裡有 可以排除含有重複元素的情況 從i 1位置開始,向後查詢比nums i 大的最小元素 ...

31 下乙個排列

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

31 下乙個排列

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