809. Expressive Words

Difficulty:
Related Topics:
Similar Questions:

    Problem

    Sometimes people repeat letters to represent extra feeling. For example:

    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 s and an array of query strings words. A query word is stretchy if it can be made to be equal to s by any number of applications of the following extension operation: choose a group consisting of characters c, and add some number of characters c to the group so that the size of the group is three or more.

    Return **the number of query strings that are *stretchy***.

      Example 1:

    Input: s = "heeellooo", words = ["hello", "hi", "helo"]
    Output: 1
    Explanation: 
    We can extend "e" and "o" in the word "hello" to get "heeellooo".
    We can't extend "helo" to get "heeellooo" because the group "ll" is not size 3 or more.
    

    Example 2:

    Input: s = "zzzzzyyyyy", words = ["zzyy","zy","zyy"]
    Output: 3
    

      Constraints:

    Solution (Java)

    class Solution {
        public int expressiveWords(String s, String[] words) {
            int ans = 0;
            for (String w : words) {
                if (check(s, w)) {
                    ans++;
                }
            }
            return ans;
        }
    
        private boolean check(String s, String w) {
            int i = 0;
            int j = 0;
            /* Logic is to check whether character at same index of S and w are same
              if same,
               1. Find the consecutive number of occurrences of the char in S (say len1) and w ( say len2)
               2. If len1 == len 2 , move to the next char in S and w
               3. If  len1 >= 3 and len2 < len1, means we can make the char in w stretchy to match len1
               4. else, return false, because it's not possible to stretch the char in w
            */
            while (i < s.length() && j < w.length()) {
                char ch1 = s.charAt(i);
                char ch2 = w.charAt(j);
    
                int len1 = getLen(s, i);
                int len2 = getLen(w, j);
                if (ch1 == ch2) {
                    if (len1 == len2 || (len1 >= 3 && len2 < len1)) {
                        i = i + len1;
                        j = j + len2;
                    } else {
                        return false;
                    }
                } else {
                    return false;
                }
            }
            return i == s.length() && j == w.length();
        }
    
        private int getLen(String value, int i) {
            i = i + 1;
            int count = 1;
            for (int j = i; j < value.length(); j++) {
                if (value.charAt(j) == value.charAt(i - 1)) {
                    count++;
                } else {
                    break;
                }
            }
            return count;
        }
    }
    

    Explain:

    nope.

    Complexity: