data:image/s3,"s3://crabby-images/44263/442633314bb99955048f361a2ae326ed317f87fa" alt=""
data:image/s3,"s3://crabby-images/6d2bf/6d2bf5a623745465f1eb343b52feb84ede95b3ee" alt=""
class Solution {
public:
void nextPermutation(vector<int>& nums) {
int i = nums.size() - 2, j = nums.size() - 1;
while(nums[i] >= nums[i+1]) i--;
if(i >= 0){
while(nums[j] <= nums[i]) j--;//这里一定要是小于等于,因为等于也不可以交换,否则就不是下一个排列组合了
swap(nums[j], nums[i]);
}
reverse(nums.begin() + i + 1, nums.end());
}
};
data:image/s3,"s3://crabby-images/cb4e0/cb4e0c2135cbb172c8878c0f609ed7a1619e1761" alt=""
http://bangbingsyb.blogspot.com/2014/11/leetcode-next-permutation.html
网友评论