LeetCode:Word Pattern - 字符串模式匹配

一、题目名称java

Word Pattern(字符串模式匹配)函数

二、题目地址code

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

三、题目内容开发

英文:Given a pattern and a string str, find if str follows the same pattern.字符串

中文:给出一组模式(pattern)和一个字符串(str),查看字符串是否与模式匹配get

例如:string

  1. pattern = "abba",str = "dog cat cat dog",返回真hash

  2. pattern = "abba",str = "dog cat cat fish",返回假it

  3. pattern = "aaaa",str = "dog cat cat dog",返回假

  4. pattern = "abba",str = "dog dog dog dog",返回假

注意:

模式仅有小写字母构成,字符串被单个空格字符隔开,字符串中每一个单词都由小写字母构成;模式和字符串的先后都不包含多余的空格;模式中的每一个字母必须匹配一个字符串中长度至少为1的单词。

四、解题方法1

使用HashMap能够很方便地解决本问题。

须要注意的是,模式中的两个不一样的字符,不能对应字符串中相同的单词。

Java代码以下:

import java.util.HashMap;

/**
 * @功能说明:LeetCode 290 - Word Pattern
 * @开发人员:Tsybius2014
 * @开发时间:2015年10月9日
 */
public class Solution {
    
    /**
     * 字符串模式匹配
     * @param pattern
     * @param str
     * @return
     */
    public boolean wordPattern(String pattern, String str) {
        
        if (pattern.isEmpty() || str.isEmpty()) {
            return false;
        }
        
        String[] s = str.split(" ");
        if (s.length != pattern.length()) {
            return false;
        }
        
        HashMap<Character, String> hashMap = new HashMap<Character, String>();
        for (int i = 0; i < pattern.length(); i++) {
            if (hashMap.containsKey(pattern.charAt(i))) {
                if (!hashMap.get(pattern.charAt(i)).equals(s[i])) {
                    return false;
                }
            } else if (hashMap.containsValue(s[i])) {
                return false;
            } else {
                hashMap.put(pattern.charAt(i), s[i]);
            }
        }
        
        return true;
    }
}

五、解题方法2

另外一个办法须要利用HashMap中put函数的性质。

put函数的声明以下:

public V put(K key, V value)

它的功能是将键值对存入map中,若是map中本来就包含要插入的键,将旧值替换为新值。对于该函数的返回值,若是要插入的键在字典中不存在,则返回null,不然返回替换前的值。根据put函数的性质,能够做出以下Java代码:

import java.util.HashMap;
import java.util.Objects;

/**
 * @功能说明:LeetCode 290 - Word Pattern
 * @开发人员:Tsybius2014
 * @开发时间:2015年10月9日
 */
public class Solution {
    
    /**
     * 模式匹配
     * @param pattern
     * @param str
     * @return
     */
    public boolean wordPattern(String pattern, String str) {
        
        if (pattern.isEmpty() || str.isEmpty()) {
            return false;
        }
        
        String[] s = str.split(" ");
        if (s.length != pattern.length()) {
            return false;
        }
        
        @SuppressWarnings("rawtypes")
        HashMap<Comparable, Integer> hashMap = new HashMap<Comparable, Integer>();
        for (int i = 0; i < pattern.length(); i++) {
            if (!Objects.equals(hashMap.put(pattern.charAt(i), i), hashMap.put(s[i], i)))
                return false;
        }
        
        return true;
    }
}

END

相关文章
相关标签/搜索