从java中的字符串中删除重复值

2022-01-10 00:00:00 string duplicates duplicate-removal java

谁能告诉我如何从

String s="Bangalore-Chennai-NewYork-Bangalore-Chennai"; 

输出应该是这样的

String s="Bangalore-Chennai-NewYork-";

使用 Java..

任何帮助将不胜感激.

推荐答案

这一行就搞定了:

public String deDup(String s) {
    return new LinkedHashSet<String>(Arrays.asList(s.split("-"))).toString().replaceAll("(^\[|\]$)", "").replace(", ", "-");
}

public static void main(String[] args) {
    System.out.println(deDup("Bangalore-Chennai-NewYork-Bangalore-Chennai"));
}

输出:

Bangalore-Chennai-NewYork

请注意订单被保留:)

重点是:

  • split("-") 将不同的值作为数组提供给我们
  • Arrays.asList() 把数组变成List
  • LinkedHashSet 保留唯一性和插入顺序 - 它完成了为我们提供唯一值的所有工作,这些值通过构造函数传递
  • List 的 toString()[element1, element2, ...]
  • 最后的 replace 命令从 toString()
  • 中删除标点符号"
  • split("-") gives us the different values as an array
  • Arrays.asList() turns the array into a List
  • LinkedHashSet preserves uniqueness and insertion order - it does all the work of giving us the unique values, which are passed via the constructor
  • the toString() of a List is [element1, element2, ...]
  • the final replace commands remove the "punctuation" from the toString()

此解决方案要求值不包含字符序列 ", " - 对此类简洁代码的合理要求.

This solution requires the values to not contain the character sequence ", " - a reasonable requirement for such terse code.

当然是1行:

public String deDup(String s) {
    return Arrays.stream(s.split("-")).distinct().collect(Collectors.joining("-"));
}

正则表达式更新!

如果您不关心保留顺序(即可以删除 first 出现的重复项):

public String deDup(String s) {
    return s.replaceAll("(\b\w+\b)-(?=.*\b\1\b)", "");
}

相关文章