题目描述:
你的朋友正在使用键盘输入他的名字 name。偶尔,在键入字符 c 时,按键可能会被长按,而字符可能
被输入 1 次或多次。你将会检查键盘输入的字符 typed。如果它对应的可能是你的朋友的名字(其中一些字符可能被长按),那么就返回 True。
例子:
输入:name = "alex", typed = "aaleex"
输出:true
解释:'alex' 中的 'a' 和 'e' 被长按。
思路:
使用双指针,遍历键盘输入的字符typed和名字name,如果字符相同,就让两个指针同时向后移;
如果字符不同,且typed中当前字符与前一字符相同,则只移动typed的指针;否则就不会成功,直接返回false
class Solution {
public boolean isLongPressedName(String name, String typed) {
int i = 0 ;
int j = 0 ;
while ( j < typed.length()){
if ( i < name.length() && name.charAt(i) == typed.charAt(j)){
i++ ;
j++ ;
}else if ( j > 0 && typed.charAt(j - 1) == typed.charAt(j)){
j++ ;
}else {
return false ;
}
}
return i == name.length() ;
}
}