gpt4 book ai didi

两个字符串数组的 Java 比较

转载 作者:行者123 更新时间:2023-12-01 01:39:49 26 4
gpt4 key购买 nike

我有一个关于以有效方式比较两个字符串数组的问题。我想知道 stArr1 的哪个字符串包含 stArr2 的任何字符串。
如果是,我想打印我在其中找到它的字符串以及 stArr1 中字符串的索引。
到目前为止,我得到的是一种比较两个字符串的简单方法:

public class Main {

public static void main(String[] args) {

String[] stArr1 = {"I am testing", "hi", "bye bye"};
String[] stArr2 = {"hello", "bye", "test"};

int matches = 0;

for (int i = 0; i < stArr1.length; i++) {
for (int j = 0; j < stArr2.length; j++) {
if (stArr1[i].contains(stArr2[j])) {
System.out.println(stArr1[i] + "found at index " i);
}
}
}
}
}
所以输出应该是:我正在测试在索引 0 处找到,在索引 2 处找到再见。
有人知道更有效的方法吗?我对流进行了一些尝试,我很确定有比这更好的解决方案。

最佳答案

您可以将 IntStreamanyMatch 运算符结合使用来完成此操作。 Streams API 是通用的,因此可以使用流执行任何实际计算。但是,仅仅因为你可以,并不意味着你应该。我仍然更喜欢迭代方法,至少对我来说,它比流解决方案更具可读性。所以,我给你的建议是保持迭代解决方案。

IntStream.range(0, stArr1.length)
.filter(i -> Arrays.stream(stArr2).anyMatch(s -> stArr1[i].contains(s)))
.forEach(i -> System.out.println(stArr1[i] + " found at index " + i));

关于两个字符串数组的 Java 比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59620177/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com