一、set.contains介绍

set.contains()函数是Java中Set接口中的一个方法,该方法判断Set中是否包含某个元素,若包含则返回true,否则返回false。
其用法为:
Set set = new HashSet<>();
set.add(element);
boolean result = set.contains(element); 其中,element为Set中的元素,result为boolean类型的变量,用于记录Set中是否包含该元素。
二、set.contains的时间复杂度
set.contains的时间复杂度与使用的Set实现有关。对于基于哈希表的实现,如HashSet和LinkedHashSet,其平均时间复杂度为O(1);对于基于红黑树的实现,如TreeSet,其平均时间复杂度为O(log n)。
在实际应用中,选用适当的Set实现能够达到更好的性能。
三、set.contains与equals的关系
set.contains的判断依赖于元素的hashCode以及equals函数的返回值。如果两个元素的hashCode相同,但equals函数返回值不同,则判断这两个元素相等的结果是错误的。
为了避免此类问题,程序员需要确保重写了元素类的equals函数,保证元素相等的判断符合自己的需求。
例如,对于一个Person类:
class Person {
    private String name;
    private int age;
    //... 
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (!(o instanceof Person)) return false;
        Person person = (Person) o;
        return age == person.age &&
                Objects.equals(name, person.name);
    }
    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }
}在使用Set时,如果只重写了hashCode函数而没有重写equals函数,则set.contains()很可能会判断出两个元素不相等,即使它们在业务上应该是相等的。
四、set.contains的使用场景
set.contains的常见使用场景包括:
判断集合中是否包含指定元素 对于删除、修改等操作,先使用set.contains判断操作元素是否存在 对于数据量比较大的List,可以先将List中的元素加入set中,再使用set.contains实现快速查找五、set.contains的应用举例
以下代码展示了如何使用set.contains实现两个字符串的交集:
public Set intersection(String s1, String s2) {
    Set set1 = new HashSet<>();
    Set set2 = new HashSet<>();
    for (char c : s1.toCharArray()) {
        set1.add(c);
    }
    for (char c : s2.toCharArray()) {
        set2.add(c);
    }
    Set result = new HashSet<>();
    for (char c : set1) {
        if (set2.contains(c)) {
            result.add(c);
        }
    }
    return result;
}    其中,set1和set2分别表示两个字符串中各个字符集合,用set.contains计算它们的交集,最终返回一个Set类型的结果。
 
             
             
       
       
                   
                   
                   
                   
                  
 
                     
                     
                     
                     
                     
                     
                     
                     
       
         京公网安备 11010802030320号
京公网安备 11010802030320号