LeetCode 925 长键按入

LeetCode 925 长键按入

问题描述
你的朋友正在使用键盘输入他的名字 name。偶尔,在键入字符 c 时,按键可能会被长按,而字符可能被输入 1 次或多次。
你将会检查键盘输入的字符 typed。如果它对应的可能是你的朋友的名字(其中一些字符可能被长按),那么就返回 True。

双指针

  • 两个指针p1、p2分别指向name、type中的当前字符,统计、计算数量、比较

执行用时:1 ms, 在所有 Java 提交中击败了86.83%的用户
内存消耗:36.5 MB, 在所有 Java 提交中击败了83.05%的用户

class Solution {
    public boolean isLongPressedName(String name, String typed) {
        if(name == null&&typed==null) {
            return true;
        }
        else if(name==null || typed==null) {
            return false;
        }
        else if(name.length()>typed.length()) {
            return false;
        }

        //双指针,p1指向name中当前字符,p2指向typed中当前字符
        int p1 = 0, p2 = 0;
        while(p1 < name.length()) {
            //记录name中当前字符的重复个数
            int n = 1;
            char ch = name.charAt(p1);
            p1++;
            while(p1<name.length() && name.charAt(p1-1)==name.charAt(p1)) {
                p1++;
                n++;
            }
            //找到typed中对应的字符重复个数
            while(p2<typed.length() && typed.charAt(p2)==ch) {
                p2++;
                n--;
            }
            if(n>0) {
                return false;
            }
        }

        return p2>=typed.length()? true: false;
    }
}
posted @ 2020-10-21 08:57  CodeSPA  阅读(85)  评论(0编辑  收藏  举报