乱序字符串

该博客介绍了如何在给定字符串数组中找出所有的乱序字符串(Anagram)。通过使用哈希表,将每个字符串转换为排序后的字符列表并用作键,存储字符串在数组中的位置作为值。当哈希表中某个键对应的值列表长度大于1时,说明存在乱序字符串,将其添加到结果列表中。
摘要由CSDN通过智能技术生成

题目描述:给出一个字符串数组S,找到其中所有的乱序字符串(Anagram)。如果一个字符串是乱序字符串,那么他存在一个字母集合相同,但顺序不同的字符串也在S中。

样例:对于字符串数组 ["lint","intl","inlt","code"],返回 ["lint","inlt","intl"]


还是使用哈希表。对于每个字符串出现的字符构成键,所在的索引构成值。这样,所有值中不止一个的,就构成了乱序字符串。

上面话说的不是很清楚。我们来看样例,首先设计键的结构:键的要求是要能表达清楚这个字符串中所有的字符,同时还要能与其他的乱序字符串直接对比。很容易想到set,但是set有两个问题,一来他无法存储重复的字符,二来,set也不可哈希。同理,list也是不可哈希的。直接对排序后的字符串做键呢?C++里面可以,此处也不行(因为Python中string是不可改变的)。所以,这里对键的设计比较麻烦。

不过,可以用这样一个办法:先将字符串转换成列表,队列表排

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值