1410. HTML Entity Parser

Difficulty:
Related Topics:
Similar Questions:

    Problem

    HTML entity parser is the parser that takes HTML code as input and replace all the entities of the special characters by the characters itself.

    The special characters and their entities for HTML are:

    Given the input text string to the HTML parser, you have to implement the entity parser.

    Return the text after replacing the entities by the special characters.

      Example 1:

    Input: text = "& is an HTML entity but &ambassador; is not."
    Output: "& is an HTML entity but &ambassador; is not."
    Explanation: The parser will replace the & entity by &
    

    Example 2:

    Input: text = "and I quote: "...""
    Output: "and I quote: \"...\""
    

      Constraints:

    Solution (Java)

    class Solution {
        public String entityParser(String text) {
            Map<String, String> map = new HashMap<>();
            map.put("&quot;", "\"");
            map.put("&apos;", "'");
            map.put("&amp;", "&");
            map.put("&gt;", ">");
            map.put("&lt;", "<");
            map.put("&frasl;", "/");
            int n = text.length();
            StringBuilder sb = new StringBuilder();
            int i = 0;
            while (i < n) {
                char c = text.charAt(i);
                if (c == '&') {
                    int index = text.indexOf(";", i);
                    if (index >= 0) {
                        String pattern = text.substring(i, index + 1);
                        if (map.containsKey(pattern)) {
                            sb.append(map.get(pattern));
                            i += pattern.length();
                            continue;
                        }
                    }
                }
                sb.append(c);
                i++;
            }
            return sb.toString();
        }
    }
    

    Explain:

    nope.

    Complexity: