Sometimes people repeat letters to represent extra feeling. For example:
"hello" -> "heeellooo""hi" -> "hiiii"In these strings like
"heeellooo", we have groups of adjacent letters that are all the same:"h","eee","ll","ooo".You are given a string
sand an array of query stringswords. A query word is stretchy if it can be made to be equal tosby any number of applications of the following extension operation: choose a group consisting of charactersc, and add some number of characterscto the group so that the size of the group is three or more.
- For example, starting with
"hello", we could do an extension on the group"o"to get"hellooo", but we cannot get"helloo"since the group"oo"has a size less than three. Also, we could do another extension like"ll" -> "lllll"to get"helllllooo". Ifs = "helllllooo", then the query word"hello"would be stretchy because of these two extension operations:query = "hello" -> "hellooo" -> "helllllooo" = s.Return the number of query strings that are stretchy.
原来来来外国人人人人都是这样说话话话话的吗吗吗吗
全校静默的第一天天天天
思路:统计words中可以转化为s的个数,转化方式为当s[i,rs] == word[j,rw]时,可以扩展word中字符使其与s相等,条件为
r
s
−
i
+
1
≥
3
rs-i+1\geq3
rs−i+1≥3。因此遍历words中的每个word,设置两个指针分别指向s和word的首部,如果字符相等,那么寻找该字符在s和word中的右边界,并判断是否需要进行扩展,以及能否进行扩展;如果字符不相等,那么一定不能进行转化,直接break
实现:
当word的长度大于s的长度时,那么一定不可以进行转化
class Solution {
public int expressiveWords(String s, String[] words) {
int len = s.length();
int count = 0;
for (String word : words){
int lenWord = word.length();
if (lenWord > len){
break;
}
int i = 0, j = 0;
while (i < len && j < lenWord && s.charAt(i) == word.charAt(j)){
int rightS = getRightBorder(s,i);
int rightWord = getRightBorder(word,j);
if (rightS - i + 1 < rightWord - j + 1){
break;
}else if (rightS - i + 1 > rightWord - j + 1 && rightS - i + 1 < 3){
break;
}
// rightS - i + 1 == rightWord - j + 1
// rightS - i + 1 > rightWord - j + 1 && rightS - i + 1 >= 3
i = rightS + 1;
j = rightWord + 1;
if (i == len && j == lenWord){
count++;
}
}
}
return count;
}
public int getRightBorder(String s,int left){
int right = left;
char c = s.charAt(left);
while (right + 1 < s.length() && s.charAt(right + 1) == c){
right++;
}
return right;
}
}