LeetCode in Kotlin

899. Orderly Queue

Hard

You are given a string s and an integer k. You can choose one of the first k letters of s and append it at the end of the string..

Return the lexicographically smallest string you could have after applying the mentioned step any number of moves.

Example 1:

Input: s = “cba”, k = 1

Output: “acb”

Explanation:

In the first move, we move the 1st character ‘c’ to the end, obtaining the string “bac”.

In the second move, we move the 1st character ‘b’ to the end, obtaining the final result “acb”.

Example 2:

Input: s = “baaca”, k = 3

Output: “aaabc”

Explanation:

In the first move, we move the 1st character ‘b’ to the end, obtaining the string “aacab”.

In the second move, we move the 3rd character ‘c’ to the end, obtaining the final result “aaabc”.

Constraints:

Solution

class Solution {
    fun orderlyQueue(s: String, k: Int): String {
        if (k > 1) {
            val ans = s.toCharArray()
            ans.sort()
            return String(ans)
        }
        var min = 'z'
        val list = ArrayList<Int>()
        for (element in s) {
            if (element < min) {
                min = element
            }
        }
        for (i in s.indices) {
            if (s[i] == min) {
                list.add(i)
            }
        }
        var ans = s
        for (integer in list) {
            val after = s.substring(0, integer)
            val before = s.substring(integer)
            val f = before + after
            if (f < ans) {
                ans = f
            }
        }
        return ans
    }
}
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy