一尘不染

检查字符串是否由唯一字符组成的最简单方法?

algorithm

我需要检查Java中的单词是否包含唯一字母(不区分大小写)。由于直接的解决方案很无聊,所以我想到了:

  1. 对于字符串中的每个字符,请检查是否indexOf(char) == lastIndexOf(char)
  2. 将所有字符添加到HashSet并检查是否设置了大小==字符串长度。
  3. 将字符串转换为char数组,按字母顺序排序,遍历数组元素并检查是否为c[i] == c[i+1]

目前,我最喜欢#2,似乎是最简单的方法。还有其他有趣的解决方案吗?


阅读 263

收藏
2020-07-28

共1个答案

一尘不染

我不喜欢1.-这是O(N 2)算法。您的2.大致是线性的,但始终遍历整个字符串。您的3.是O(N lg 2 N),(可能)有一个相对较高的常数-
可能几乎总是比2慢。

但是,我的首选是,当您尝试将字母插入集合中时,检查它是否已经存在,如果已经存在,则可以立即停止。给定字母的随机分布,平均应该只扫描一半的字符串。

编辑:这两个评论都是正确的,您希望扫描的字符串的确切部分将取决于分布和长度-
在某些时候,字符串足够长以至于不可避免的重复,并且(例如)缺少一个字符那个机会仍然很高。实际上,给定平坦的随机分布(即,集合中的所有字符均具有相同的可能性),这应与生日悖论紧密吻合,这意味着发生碰撞的机会与字符中可能出现的字符数的平方根有关。字符集。举例来说,如果我们假设基本US-
ASCII(128个字符)具有相同的概率,则在大约14个字符处发生冲突的可能性为50%。当然,在实际的字符串中,我们可能会比它早一些,因为ASCII字符不是’

2020-07-28