码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode Word Pattern

时间:2015-12-04 22:44:12      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:

题目连接

https://leetcode.com/problems/word-pattern/  

Word Pattern

Description

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.

class Solution {
public:
	bool wordPattern(string pattern, string str) {
		unordered_map<string, char> A;
		unordered_map<char, string> B;
		size_t p, i, j = 0, n = pattern.length();
		for (i = 0; i < n; i++) {
			char &ch = pattern[i];
			p = str.find(‘ ‘, j);
			string ret = str.substr(j, p - j);
			if (A.find(ret) == A.end()) A[ret] = ch;
			else if (A[ret] != ch) return false;
			if (B.find(ch) == B.end()) B[ch] = ret;
			else if (B[ch] != ret) return false;
			j = p + 1;
		}
		return i == pattern.size() && p == string::npos;
	}
};

leetcode Word Pattern

标签:

原文地址:http://www.cnblogs.com/GadyPu/p/5020558.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!