290. Word Pattern

Given a pattern
and a string str
, find if str
follows the same pattern.
Here follow means a full match, such that there is a bijection between a letter in pattern
and a non-empty word in str
.
Examples:
pattern = "abba"
, str = "dog cat cat dog"
should return true.
pattern = "abba"
, str = "dog cat cat fish"
should return false.
pattern = "aaaa"
, str = "dog cat cat dog"
should return false.
pattern = "abba"
, str = "dog dog dog dog"
should return false.

Notes:You may assume pattern
contains only lowercase letters, and str
contains lowercase letters separated by a single space.

這道題和205神像,直接寫方法了:

/**
 * @param {string} pattern
 * @param {string} str
 * @return {boolean}
 */
var wordPattern = function(pattern, str) {
    
    var word = "";
    var count = 0;
    var patternMap = {};
    var wordMap = {};
    str += " ";
    var num = str.length;
    for (var i = 0;i < num;i++) {
        if (str[i]!==" ") {
            word += str[i];
        } else {
            if (patternMap[pattern[count]]!==wordMap[word]) 
                return false;
            if (patternMap[pattern[count]]===undefined) {
                patternMap[pattern[count]] = count;
                wordMap[word] = count;
            }
            word = "";
            count++;
        }
    }
    if (count!==pattern.length)
        return false;
    return true;
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容