标题:长按键入
内容:你的朋友正在使用键盘输入他的名字 name。偶尔,在键入字符 c 时,按键可能会被长按,而字符可能被输入 1 次或多次。
你将会检查键盘输入的字符 typed。如果它对应的可能是你的朋友的名字(其中一些字符可能被长按),那么就返回 True。
示例 1:
输入:name = "alex", typed = "aaleex"
输出:true
解释:'alex' 中的 'a' 和 'e' 被长按。
示例 2:
输入:name = "saeed", typed = "ssaaedd"
输出:false
解释:'e' 一定需要被键入两次,但在 typed 的输出中不是这样。
示例 3:
输入:name = "leelee", typed = "lleeelee"
输出:true
示例 4:
输入:name = "laiden", typed = "laiden"
输出:true
解释:长按名字中的字符并不是必要的。
def isLongPressedName(name, typed):
"""
:type name: str
:type typed: str
:rtype: bool
"""
i,name_len = 0,len(name)
for j in range(len(typed)):
if i < name_len and typed[j] == name[i]: # 判断输入的字符是否和真实的字符相等,且没有超出索引范围
i += 1 # 如果条件成立,那么就判断下一个字符,通过索引增加1来往后逐一判断
elif j == 0 or typed[j] != typed[j-1]: # 根据if判断语句的特性,第一个条件不成立(输入的和真实的不一致),才会执行第二个条件,如果第一个字母就不一样,或者输入的这个字符和前一个字符不一致,那么直接返回false
#print(j)
return False
return i == name_len # 最后再判断:如果i和name的长度相等,判断typed是否在最后还输入了超出且和name最后一个字符不一致的字符
print('name = "alex", typed = "aaleex"',isLongPressedName("alex","aaleex"))
print('name = "saeed", typed = "ssaaedd"',isLongPressedName("saeed","ssaaedd"))
print('name = "leelee", typed = "lleeelee"',isLongPressedName("leelee","lleeelee"))
print('name = "laiden", typed = "laiden"',isLongPressedName("laiden","laiden"))
来源:https://www.cnblogs.com/su-sir/p/12014816.html