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

LeetCode-Group Shifted Strings

时间:2016-09-14 07:19:49      阅读:226      评论:0      收藏:0      [点我收藏+]

标签:

Given a string, we can "shift" each of its letter to its successive letter, for example: "abc" -> "bcd". We can keep "shifting" which forms the sequence:

"abc" -> "bcd" -> ... -> "xyz"

Given a list of strings which contains only lowercase alphabets, group all strings that belong to the same shifting sequence.

For example, given: ["abc", "bcd", "acef", "xyz", "az", "ba", "a", "z"],
A solution is:

[
  ["abc","bcd","xyz"],
  ["az","ba"],
  ["acef"],
  ["a","z"]
]
 
Solution:
public class Solution {
    public List<List<String>> groupStrings(String[] strings) {
        List<List<String>> resLists = new LinkedList<List<String>>();
        
        HashMap<String,List<String>> patternMap = new HashMap<String,List<String>>();
        for (String str : strings){
            StringBuilder builder = new StringBuilder().append(str);
            int delta = builder.charAt(0)-‘a‘;
            builder.setCharAt(0,‘a‘);
            for (int i=1;i<builder.length();i++){
                char c = (char) ((builder.charAt(i) + 26 - delta)%26);
                builder.setCharAt(i,c);
            }
            String pattern = builder.toString();
            if (!patternMap.containsKey(pattern)){
                patternMap.put(pattern,new LinkedList<String>());
            }
            patternMap.get(pattern).add(str);
        }
        
        for (List<String> strList : patternMap.values()){
            resLists.add(strList);
        }
        return resLists;
    }
}

 

 

LeetCode-Group Shifted Strings

标签:

原文地址:http://www.cnblogs.com/lishiblog/p/5870504.html

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