我必须检查字符串数组test2[]
是否包含值test1[]
。怎么做?两个阵列的大小不同。我还必须检查test2[]
是否包含test1[]
的子字符串。
String[] test = {"Test1", "Test2"};
String[] test2 = {"Test3", "Test4", "Test5", "Test6", "Test1 - Test7"};
非常感谢。
答案 0 :(得分:1)
您只需要几个嵌套循环并进行迭代。您的问题模棱两可,您说的contains
一词可能表示equals
或contains the substring
。无论哪种情况,如果您想要相等的匹配,只需将.contains()
替换为.equals()
。
for (String value : test) {
for (String sampleString : test2) {
if (sampleString.contains(value)) {
System.out.println("Value " + value + " is contained in the array in " + sampleString);
}
}
}
答案 1 :(得分:0)
public boolean checkIfHaveSameElements(String[] test1, String[] test2) {
for (String str2 : test2) {
for (String str1 : test1) {
if (str2.equals(str1)) {
return true;
}
}
}
return false;
}
只需将数组作为方法调用参数传递即可。
答案 2 :(得分:0)
您可以使用两个for循环,一个用于循环test
,另一个用于检查项目是否包含在test2
public static boolean checkIfExists(String[] arr, String item) {
for (String n : arr) {
if (n.contains(item)) {
return true;
}
}
return false;
}
在主要方法中
String[] test = {"Test1", "Test2"};
String[] test2 = {"Test3", "Test4", "Test5", "Test6", "Test1 - Test7"};
for(String t : test) {
System.out.println(checkIfExists(test2, t));
}
答案 3 :(得分:0)
使用Java 8 API,我首先要检查整个字符串是否存在或子字符串是否存在。
public class CheckString {
public static void main(String[] args) {
String[] test = {"Test1", "Test3", "Test2"};
String[] test2 = {"Test3", "Test4", "Test5", "Test6", "Test1 - Test7"};
boolean isPresent = Arrays.stream(test2)
.filter(str->{
return Arrays.asList(test).indexOf(str) > 0 || checkString(test,str);
})
.collect(Collectors.toList())
.isEmpty();
System.out.println(!isPresent);
}
private static boolean checkString(String[] strs, String chkStr){
for(String str: strs){
if(chkStr.contains(str)){
return true;
}
}
return false;
}
}