1593. Split a String Into the Max Number of Unique Substrings

1593. Split a String Into the Max Number of Unique Substrings

Description

Given a strings, return the maximum number of unique substrings that the given string can be split into.

You can split strings into any list of non-empty substrings , where the concatenation of the substrings forms the original string.However, you must split the substrings such that all of them are unique .

A substring is a contiguous sequence of characters within a string.

Example 1:

1
2
Input: s = "ababccc"
Output: 5

Explanation:

One way to split maximally is [‘a’, ‘b’, ‘ab’, ‘c’, ‘cc’]. Splitting like [‘a’, ‘b’, ‘a’, ‘b’, ‘c’, ‘cc’] is not valid as you have ‘a’ and ‘b’ multiple times.

Example 2:

1
2
Input: s = "aba"
Output: 2

Explanation:

One way to split maximally is [‘a’, ‘ba’].

Example 3:

1
2
Input: s = "aa"
Output: 1

Explanation:

It is impossible to split the string any further.

Constraints:

  • 1 <= s.length<= 16
  • s contains only lower case English letters.

Hints/Notes

  • 2024/10/01
  • back tracking
  • No solution from 0x3F

Solution

Language: C++

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
class Solution {
public:
unordered_set<string> us;
int res; string s_;
int maxUniqueSplit(string s) {
res = INT_MIN; s_ = s;
dfs(0);
return res;
}

void dfs(int index) {
if (index == s_.size()) {
res = max(res, (int)us.size());
return;
}
for (int i = index + 1; i <= s_.size(); i++) {
string tmp = s_.substr(index, i - index);
if (!us.contains(tmp)) {
us.insert(tmp);
dfs(i);
us.erase(tmp);
}
}
}
};