public class Solution {
/*
* @param nums: A list of integers
* @return: A list of integers that's previous permuation
*/
public List<Integer> previousPermuation(List<Integer> nums) {
// write your code here
int len = nums.size();
if (len < 2) {
return nums;
}
int index = len - 1;
while (index > 0) {
if (nums.get(index - 1) > nums.get(index)) {
break;
}
index--;
}
if (index == 0) {
reverse(nums, 0, len - 1);
return nums;
}
int val = nums.get(index - 1);
int j = len - 1;
while (index <= j) {
if (nums.get(j) < val) {
break;
}
j--;
}
swap(nums, j, index - 1);
reverse(nums, index, len - 1);
return nums;
}
public void swap(List<Integer> nums, int i, int j) {
Integer tmp = nums.get(i);
nums.set(i, nums.get(j));
nums.set(j, tmp);
}
public void reverse(List<Integer> nums, int i, int j) {
while (i < j) {
swap(nums, i, j);
i++; j--;
}
}
}
public class Solution {
/**
* @param nums: A list of integers
* @return: A list of integers
*/
public int[] nextPermutation(int[] nums) {
// write your code here
int len = nums.length;
if (len < 2) {
return nums;
}
int index = len - 1;
while (index > 0) {
if (nums[index - 1] < nums[index]) {
break;
}
index--;
}
if (index == 0) {
reverse(nums, 0, len - 1);
return nums;
}
int val = nums[index - 1];
int j = len - 1;
while (index <= j) {
if (nums[j] > val) {
break;
}
j--;
}
swap(nums, j, index - 1);
reverse(nums, index, len - 1);
return nums;
}
public void swap(int[] nums, int i, int j) {
int tmp = nums[i];
nums[i] = nums[j];
nums[j] = tmp;
}
public void reverse(int[] nums, int i, int j) {
while (i < j) {
swap(nums, i, j);
i++; j--;
}
}
}