Set判断元素是否已存在的条件

1、判断变量是否存在相同的引用,如果引用相同,则不再判断hashcode、equals,并且认为已存在该元素,无法添加元素

2、如果指向不同的引用,则判断hashcode和equals是否一样,同时一样则认为已存在。

package p1;

import java.util.HashSet;

public class A {
    
    public static void main(String[] args) {
        A1 a1 = new A1();
        A1 a2 = a1;
        A1 a3 = a1;
        HashSet<A1> set = new HashSet<A1>();
        set.add(a1);
        set.add(a2);
        set.add(a3);
        System.out.println(set.size());
    }
}

class A1 {
    @Override
    public int hashCode() {
        // TODO Auto-generated method stub
        return 11;
    }
    
    @Override
    public boolean equals(Object obj) {
        // TODO Auto-generated method stub
        // return super.equals(obj);
        return false;
    }
}

------ 答案:1

 

package p1;

import java.util.HashSet;

public class A {
    
    public static void main(String[] args) {
        A1 a1 = new A1();
        A1 a2 = new A1();
        HashSet<A1> set = new HashSet<A1>();
        set.add(a1);
        set.add(a2);
        System.out.println(set.size());
    }
}

class A1 {
    @Override
    public int hashCode() {
        // TODO Auto-generated method stub
        return 11;
    }
    
    @Override
    public boolean equals(Object obj) {
        // TODO Auto-generated method stub
        // return super.equals(obj);
        return false;
    }
}

--------- 答案:2

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,List是一个有序的可重复集合,因此不存在直接的互斥关系。如果你想判断List中是否存在互斥的元素,你需要定义什么样的元素才被认为是互斥的。 假设你有一个List<List<Integer>>,其中每个内部List表示一组元素。你可以通过遍历List中的每个内部List,并判断是否存在相同的元素判断是否存在互斥。你可以使用Set来辅助判断是否存在重复元素,因为Set不允许重复元素。 下面是一个示例代码,演示如何判断List中是否存在互斥的元素: ```java List<List<Integer>> listOfLists = new ArrayList<>(); listOfLists.add(Arrays.asList(1, 2, 3)); listOfLists.add(Arrays.asList(4, 5, 6)); listOfLists.add(Arrays.asList(7, 8, 9)); boolean hasMutualExclusive = false; Set<Integer> set = new HashSet<>(); for (List<Integer> list : listOfLists) { for (Integer num : list) { if (!set.add(num)) { hasMutualExclusive = true; break; } } if (hasMutualExclusive) { break; } } if (hasMutualExclusive) { System.out.println("存在互斥的元素"); } else { System.out.println("不存在互斥的元素"); } ``` 上述代码首先创建一个List<List<Integer>>,然后使用两层循环遍历每个内部List中的元素。在遍历过程中,使用Set判断是否存在重复元素,如果存在重复元素,则认为存在互斥的情况。最后根据hasMutualExclusive变量的值来输出结果。 请注意,这里的互斥是基于元素的值是否相同来判断的。如果你有其他的互斥条件,请根据具体情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值