java - Java 中的 str.contains

标签 java string string-matching contain

我有 2 个列表

allWords [book, pen, pencil] 
subsetString [book  pen  , book  pencil  , pen  pencil  ]

我期望我的输出为

book  pen => pencil
book  pencil => pen
pen  pencil => book

即对于subsetString 中的每个元素,我将使用allwords 检查它。 一旦找不到匹配项,所有单词中的字符串将被添加到输出的 RHS

但我的问题是 现在我只得到 2 个输出而不是 3 个

allWords [book, pen, pencil]
subsetString [book  pen  , book  pencil  , pen  pencil  ]
pen  pencil   => book
book  pen   => pencil

原因是当进入book Pencil时,它会被allWords [book, pen,pencil]检查

一旦 pen 包含 book Pencil - 它就很满意(因为 pencil 包含子字符串 pen)。

代码

public void getStrongRules2(ArrayList<String> allWords,String delim) {
        ArrayList<ArrayList<String>> subsets = BTSum(allWords);
        ArrayList<String> subsetString = new ArrayList<String>();

        for (int j = 0; j < subsets.size(); j++) {
            String substring = "";
            for (int k = 0; k < subsets.get(j).size(); k++) {

                substring += subsets.get(j).get(k) + "  ";
            }
            subsetString.add(substring);
        }
        System.out.println("allWords "+allWords);
        System.out.println("subsetString "+subsetString);

        for(String a : allWords){
            for (int j = 0; j < subsetString.size(); j++) {
                if (!(subsetString.get(j).contains(a))) {
                    System.out.println(subsetString.get(j)+" => "+a);
                }
            }
        }
    }
    public static ArrayList<ArrayList<String>> BTSum(ArrayList<String> numbers) {

        int n = numbers.size();
        ArrayList<ArrayList<String>> powerSet = new ArrayList<ArrayList<String>>();

        for (long i = 0; i < (1 << n); i++) {
            ArrayList<String> element = new ArrayList<String>();
            for (int j = 0; j < n; j++)
                if ((i >> j) % 2 == 1) {
                    element.add(numbers.get(j));
                }
            if (element.size() > 1 && element.size() < n) {
                powerSet.add(element);
            }
        }
        return powerSet;
    }

}

但这不应该发生在我的例子中。

如何纠正这个问题。

请提出建议

最佳答案

考虑

     List<String> allWords = new ArrayList<>();
     allWords.add("Book"); allWords.add("Pen"); allWords.add("Pencil") ; 

如果您能够将子集拆分为三个不同的列表而不是单个 arrayList,请像 split

     list1 [Book,Pen] 
     list2 [Book,Pencil]
     list3 [Pen,Pencil]

你可以遵循这个而不做循环

     Set<String> results1 = new HashSet<String>(allWords);
     results1.removeAll(list1);
     System.out.println("result1 : "+ list1 +" ===> "+ results1);

     Set<String> results2 = new HashSet<String>(allWords);
     results2.removeAll(list2);
     System.out.println("result2 : "+ list2 +" ===> "+ results2);

     Set<String> results3 = new HashSet<String>(allWords);
     results3.removeAll(list3);
     System.out.println("result3 : "+ list3 +" ===> "+ results3);

输出

result1 : [Book, Pen] ===> [Pencil]
result2 : [Book, Pencil] ===> [Pen]
result3 : [Pen, Pencil] ===> [Book]

希望这有帮助

关于java - Java 中的 str.contains,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25153208/

相关文章:

java - 使用 JSON 从字符串中解析数组?

python - 从字符串中删除括号之间的内容

Python:如何在字符串列表中查找匹配最多的字符串

excel - 使用 Excel 在字母数字字符串中出现的某些字母的总和

java - WSO2 APIM 1.10 : I'm getting following exception when i started server

java - 如何使用 Eclipse JDT ASTParser 获取方法的类名?

c# - 多个级别的特殊字符串模式的正则表达式

python - string "c"是最新项,为什么不break?

octave - 在向量中搜索特定字符串( Octave )

java - 如何为Java源代码创建数据流图