我有两个字符串str,str2。两个字符串都有空格。我使用包含方法,但它不适合此处,因为它只检查确切的字符。如何在这里检查一个字符串是否是子字符串。
我使用以下代码实现了它。因此,如果原始字符串中存在String“FOO BAR”,则代码中的函数将打印为true。
public static void main(String[] args) {
String str = "FOO BAR";
String str1 = "FOO T BAR";
String orignialString;
String stringToMatch;
if (str1.length() > str.length()) {
orignialString = str1;
stringToMatch = str;
} else {
orignialString = str1;
stringToMatch = str;
}
boolean flag = false;
String[] stringarr = stringToMatch.split(" ");
for (int i = 0; i < stringarr.length; i++) {
if (orignialString.contains(stringarr[i])) {
flag = true;
} else {
flag = false;
break;
}
}
System.out.println("IS SUBSTRING---> " + flag);
}
我正在使用Pattern Matcher / REGEX寻找更干净的短代码。
答案 0 :(得分:1)
这个答案假定您要将FOO BAR
标识为FOO T BAR
的子字符串,因为前者的所有单词也在后者中作为单词出现。使用这个逻辑,我们可以只从两个字符串中的每个字符串形成单词列表,然后迭代以检查所有单词是否存在。
boolean isSub = true;
String str = "FOO T BAR";
String str1 = "FOO BAR";
List<String> strList = Arrays.asList(str.split("\\s+"));
List<String> strSubList = Arrays.asList(str1.split("\\s+"));
for (String sub : strSubList) {
if (!strList.contains(sub)) {
isSub = false;
}
}
System.out.println("input is a substring: " + isSub);