1370. Increasing Decreasing String

Difficulty:
Related Topics:
Similar Questions:

    Problem

    You are given a string s. Reorder the string using the following algorithm:

    In each step, If the smallest or the largest character appears more than once you can choose any occurrence and append it to the result.

    Return **the result string after sorting *s* with this algorithm**.

      Example 1:

    Input: s = "aaaabbbbcccc"
    Output: "abccbaabccba"
    Explanation: After steps 1, 2 and 3 of the first iteration, result = "abc"
    After steps 4, 5 and 6 of the first iteration, result = "abccba"
    First iteration is done. Now s = "aabbcc" and we go back to step 1
    After steps 1, 2 and 3 of the second iteration, result = "abccbaabc"
    After steps 4, 5 and 6 of the second iteration, result = "abccbaabccba"
    

    Example 2:

    Input: s = "rat"
    Output: "art"
    Explanation: The word "rat" becomes "art" after re-ordering it with the mentioned algorithm.
    

      Constraints:

    Solution (Java)

    class Solution {
        public String sortString(String s) {
            int[] count = new int[26];
            for (char c : s.toCharArray()) {
                count[c - 'a']++;
            }
            StringBuilder sb = new StringBuilder();
            while (sb.length() < s.length()) {
                for (int i = 0; i < count.length; i++) {
                    if (count[i] != 0) {
                        char character = (char) (i + 'a');
                        sb.append(character);
                        count[i]--;
                    }
                }
                for (int i = 25; i >= 0; i--) {
                    if (count[i] > 0) {
                        char character = (char) (i + 'a');
                        sb.append(character);
                        count[i]--;
                    }
                }
            }
            return sb.toString();
        }
    }
    

    Explain:

    nope.

    Complexity: