Set.contains()如何决定它是否是一个子集?

时间:2013-07-24 02:13:33

标签: java iterator set subset hashset

我希望以下代码能给我一个子集和一个补充集。

但实际上,结果显示“错误:这不是一个子集!”

it.next()得到什么以及如何修改我的代码以获得我想要的结果? 谢谢!

package Chapter8;

import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;

public class Three {
    int n;
    Set<Integer> set = new HashSet<Integer>();

    public static void main(String args[]) {
        Three three = new Three(10);
        three.display(three.set);
        Set<Integer> test = new HashSet<Integer>();
        Iterator<Integer> it = three.set.iterator();
        while(it.hasNext()) {
            test.add(it.next());
            three.display(test);
            three.display(three.complementarySet(test));
        }

    }

    boolean contains(Set<Integer> s) {
        if (this.set.contains(s))
            return true;
        else 
            return false;
    }

    Set<Integer> complementarySet(Set<Integer> s) {
        if(this.set.contains(s)){
            Set<Integer> result = this.set;
            result.removeAll(s);
            return result;
        }
        else {
            System.out.println("Error: This is not a subset!");
            return null;
        }
    }

    Three() {
        this.n = 3;
        this.randomSet();
    }

    Three(int n) {
        this.n = n;
        this.randomSet();
    }

    void randomSet() {
        while(set.size() < n) {
            set.add((int)(Math.random()*10));
        }
    }

    void display(Set<Integer> s) {
        System.out.println("The set is " + s.toString());
    }
}

2 个答案:

答案 0 :(得分:29)

您可能希望使用set.containsAll(Collection <?> C)来检查Collection(在本例中为Set)是否为'set'的子集。来自文档:http://docs.oracle.com/javase/7/docs/api/java/util/Set.html#containsAll(java.util.Collection)

  

boolean containsAll(Collection c)

     

如果此set包含指定的所有元素,则返回true   采集。如果指定的集合也是一个集合,则此方法   如果它是此集合的子集,则返回true。

答案 1 :(得分:3)

你的问题在于这一部分:

set.contains(s)

不能按照您的想法执行,它不会将另一个Set作为参数,以查看其成员是否包含在第一个set中。它看起来是否传递它的参数是在Set。

您需要迭代“包含”集合,并对所包含集合中的每个元素使用set.contains(element)