单词模式

 

思路:用两个hash表来存储pattern中每个字母对应的word和单词中每个word对应的pattern中的字母。

def word_pattern(pattern, words):
    '''

    :param pattern: str
    :param words: str
    :return: boolean
    '''
    word_list = words.split()
    word_buffer = {}
    pattern_buffer = {}
    i = 0
    if len(word_list) != len(pattern):
        return False
    for each in word_list:
        if each in word_buffer.keys():
            if word_buffer.get(each) == pattern[i]:
                i += 1
                continue
            else:
                return False
        else:
            if pattern[i] in pattern_buffer.keys():
                return False
            else:
                word_buffer[each] = pattern[i]
                pattern_buffer[pattern[i]] = each
                i += 1
    return True

以下是我在leetcode上提交的结果:

leetcode上的题目的地址是:https://leetcode.com/problems/word-pattern/description/

 

posted @ 2018-06-22 22:37  whatyouknow123  阅读(328)  评论(0编辑  收藏  举报