题目:
给你一个字符串 s
,请你将该字符串划分成一个或多个 子字符串 ,并满足每个子字符串中的字符都是 唯一 的。也就是说,在单个子字符串中,字母的出现次数都不超过 一次 。
满足题目要求的情况下,返回 最少 需要划分多少个子字符串。
注意,划分后,原字符串中的每个字符都应该恰好属于一个子字符串。
示例 1:
输入:s = "abacaba" 输出:4 解释: 两种可行的划分方法分别是 ("a","ba","cab","a") 和 ("ab","a","ca","ba") 。 可以证明最少需要划分 4 个子字符串。
示例 2:
输入:s = "ssssss" 输出:6 解释: 只存在一种可行的划分方法 ("s","s","s","s","s","s") 。
想法:
本题涉及贪心、字符串及哈希表,属中等难度。在字符串中遇到了重复的字母即需要划分一次,可以通过哈希表来统计字母出现的次数,如果重复出现,就将哈希表置零,字符串个数增加。反之,则记录一次进入哈希表。
代码如下:
int partitionString(char* s) {
int hash[26] = {0}, cnt = 0;
for(int i = 0; s[i]; i++){
if(hash[s[i] -'a']){
memset(hash, 0, sizeof(hash));
cnt++;
}
hash[s[i] - 'a'] = 1;
}
return cnt + 1;
}