All Downloads are FREE. Search and download functionalities are using the official Maven repository.

g1001_1100.s1053_previous_permutation_with_one_swap.Solution Maven / Gradle / Ivy

package g1001_1100.s1053_previous_permutation_with_one_swap;

// #Medium #Array #Greedy #2022_02_28_Time_0_ms_(100.00%)_Space_56.1_MB_(27.21%)

/**
 * 1053 - Previous Permutation With One Swap\.
 *
 * Medium
 *
 * Given an array of positive integers `arr` (not necessarily distinct), return _the lexicographically largest permutation that is smaller than_ `arr`, that can be **made with exactly one swap** (A _swap_ exchanges the positions of two numbers `arr[i]` and `arr[j]`). If it cannot be done, then return the same array.
 *
 * **Example 1:**
 *
 * **Input:** arr = [3,2,1]
 *
 * **Output:** [3,1,2]
 *
 * **Explanation:** Swapping 2 and 1.
 *
 * **Example 2:**
 *
 * **Input:** arr = [1,1,5]
 *
 * **Output:** [1,1,5]
 *
 * **Explanation:** This is already the smallest permutation.
 *
 * **Example 3:**
 *
 * **Input:** arr = [1,9,4,6,7]
 *
 * **Output:** [1,7,4,6,9]
 *
 * **Explanation:** Swapping 9 and 7.
 *
 * **Constraints:**
 *
 * *   1 <= arr.length <= 104
 * *   1 <= arr[i] <= 104
**/
public class Solution {
    public int[] prevPermOpt1(int[] arr) {
        for (int i = arr.length - 1; i >= 0; i--) {
            int diff = Integer.MAX_VALUE;
            int index = i;
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[i] - arr[j] > 0 && diff > arr[i] - arr[j]) {
                    diff = arr[i] - arr[j];
                    index = j;
                }
            }
            if (diff != Integer.MAX_VALUE) {
                int temp = arr[i];
                arr[i] = arr[index];
                arr[index] = temp;
                break;
            }
        }
        return arr;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy