题目链接:
https://leetcode-cn.com/problems/long-pressed-name/
难度:简单
925. 长按键入
你的朋友正在使用键盘输入他的名字 name。偶尔,在键入字符 c 时,按键可能会被长按,而字符可能被输入 1 次或多次。
你将会检查键盘输入的字符 typed。如果它对应的可能是你的朋友的名字(其中一些字符可能被长按),那么就返回 True。
示例 1:
输入:name = "alex", typed = "aaleex"
输出:true
解释:'alex' 中的 'a' 和 'e' 被长按。
示例 2:
输入:name = "saeed", typed = "ssaaedd"
输出:false
解释:'e' 一定需要被键入两次,但在 typed 的输出中不是这样。
简单题。。。
双指针
class Solution {
public:
bool isLongPressedName(string name, string typed) {
int n=name.size(),m=typed.size();
// 若是name的长度还大于typed 必为错
if(n>m){
return false;
}
int i=0,j=0;
// 对typed进行枚举
while(j<m){
// 枚举过程中有三种情况:
// typed[j]==name[i] i和j同时加一进行下一序列的比对
// typed[j]!=name[i] 有两种情况:
// typed[j]!=typed[j-1] 返回false
// typed[j]==typed[j-1] j++ 说明typed[j]重复按了
if(i<n&&typed[j]==name[i]){
++i;
++j;
}else if(j>0&&typed[j]==typed[j-1]){
++j;
}else{
return false;
}
}
// 循环结束后typed已经枚举完成
// 查看 name是否正好枚举结束
return i==n;
}
};