【题目描述】
Given an array of strings, return all groups of strings that are anagrams.
【注】:All inputs will be in lower-case
给出一个字符串数组S,找到其中所有的乱序字符串(Anagram)。如果一个字符串是乱序字符串,那么他存在一个字母集合相同,但顺序不同的字符串也在S中。
【注】:所有的字符串都只包含小写字母
【题目链接】
www.lintcode.com/en/problem/anagrams/
【题目解析】
所谓“换位词/变位词”就是包含相同字母,但字母顺序可能不同的字符串。比如“abc", "bca", "cab", "acb", "bac", "cba"都互为换位词。
很容易想到,这些换位词如果按字母序排序后都是”abc“,所以可以对原数组中每个字符串自身进行排序,然后出现过两次以上的就是我们要找的字符串。
需要注意的是,要保持原字符串数组不变,那么就需要一个同样大小的数组来存储排序后的每个字符串。
接下来的问题是,如何找出出现两次以上的字符串对应的原字符串,这个用代码比较难以实现,两层for循环的暴力解决会超时。再用一个同样大小的数组标记相应下标位置的原字符串是否为“换位词”,这样需要一边遍历,然后再一边遍历把相应位置的原字符串添加到结果集中。
【参考答案】