检查String是否包含由空格分隔的子字符串

时间:2017-08-23 10:28:56

标签: java string pattern-matching

我有两个字符串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寻找更干净的短代码。

1 个答案:

答案 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);

Demo