2138. Divide a String Into Groups of Size k

Difficulty:
Related Topics:
Similar Questions:

Problem

A string s can be partitioned into groups of size k using the following procedure:

Note that the partition is done so that after removing the fill character from the last group (if it exists) and concatenating all the groups in order, the resultant string should be s.

Given the string s, the size of each group k and the character fill, return **a string array denoting the *composition of every group* s has been divided into, using the above procedure**.

  Example 1:

Input: s = "abcdefghi", k = 3, fill = "x"
Output: ["abc","def","ghi"]
Explanation:
The first 3 characters "abc" form the first group.
The next 3 characters "def" form the second group.
The last 3 characters "ghi" form the third group.
Since all groups can be completely filled by characters from the string, we do not need to use fill.
Thus, the groups formed are "abc", "def", and "ghi".

Example 2:

Input: s = "abcdefghij", k = 3, fill = "x"
Output: ["abc","def","ghi","jxx"]
Explanation:
Similar to the previous example, we are forming the first three groups "abc", "def", and "ghi".
For the last group, we can only use the character 'j' from the string. To complete this group, we add 'x' twice.
Thus, the 4 groups formed are "abc", "def", "ghi", and "jxx".

  Constraints:

Solution (Java)

class Solution {
    public String[] divideString(String s, int k, char fill) {
        String[] ans = new String[(s.length() % k != 0) ? (s.length() / k) + 1 : s.length() / k];
        int t = k;
        List<String> str = new ArrayList<>();
        StringBuilder sb = new StringBuilder();
        int i = 0;
        while (i < s.length()) {
            if (t > 0) {
                sb.append(s.charAt(i));
                t--;
            } else {
                t = k;
                str.add(sb.toString());
                sb.setLength(0);
                i--;
            }
            i++;
        }
        if (t > 0) {
            while (t-- > 0) {
                sb.append(fill);
            }
        }
        str.add(sb.toString());
        for (int j = 0; j < str.size(); j++) {
            ans[j] = str.get(j);
        }
        return ans;
    }
}

Explain:

nope.

Complexity: