题目描述:给出一个字符串数组S,找到其中所有的乱序字符串(Anagram)。如果一个字符串是乱序字符串,那么他存在一个字母集合相同,但顺序不同的字符串也在S中。
样例:对于字符串数组 ["lint","intl","inlt","code"],返回 ["lint","inlt","intl"]
还是使用哈希表。对于每个字符串出现的字符构成键,所在的索引构成值。这样,所有值中不止一个的,就构成了乱序字符串。
上面话说的不是很清楚。我们来看样例,首先设计键的结构:键的要求是要能表达清楚这个字符串中所有的字符,同时还要能与其他的乱序字符串直接对比。很容易想到set,但是set有两个问题,一来他无法存储重复的字符,二来,set也不可哈希。同理,list也是不可哈希的。直接对排序后的字符串做键呢?C++里面可以,此处也不行(因为Python中string是不可改变的)。所以,这里对键的设计比较麻烦。
不过,可以用这样一个办法:先将字符串转换成列表,队列表排