zoukankan      html  css  js  c++  java
  • 290. Word Pattern(LeetCode)

    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:

    1. pattern = "abba", str = "dog cat cat dog" should return true.
    2. pattern = "abba", str = "dog cat cat fish" should return false.
    3. pattern = "aaaa", str = "dog cat cat dog" should return false.
    4. 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.

     1 class Solution {
     2 public:
     3     bool wordPattern(string pattern, string str) {
     4        istringstream strcin(str);
     5         string s;
     6         vector<string> vs;
     7         while(strcin >> s) vs.push_back(s);
     8         if (pattern.size() != vs.size()) return false;
     9         map<string, char> s2c;
    10         map<char, string> c2s;
    11         for (int i = 0; i < vs.size(); ++i) {
    12             if (s2c[vs[i]] == 0 && c2s[pattern[i]] == "") { 
    13                 s2c[vs[i]] = pattern[i]; 
    14                 c2s[pattern[i]] = vs[i]; 
    15                 continue; 
    16             }
    17             if (s2c[vs[i]] != pattern[i]) return false;
    18         }
    19         return true;
    20     }
    21 };
  • 相关阅读:
    mode
    文件操作
    深浅拷贝
    基础数据类型补充
    再谈编码 decode和encode
    Python练习题 015:一颗自由落地的球
    Python练习题 014:完数
    Python练习题 013:求解a+aa+aaa……
    Python练习题 012:字符统计
    Python练习题 011:成绩打分
  • 原文地址:https://www.cnblogs.com/wujufengyun/p/7121073.html
Copyright © 2011-2022 走看看