取两个集合List的交集、补集、并集、差集的几种方式

目录

一、apache工具包

二、hutool工具包

三、stream方式

四、Collection接口中的方法


首先知道几个单词的意思:

交集 = intersection
并集 = union
补集 = complement
析取 = disjunction
减去 = subtract

一、apache工具包

导入依赖

        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-collections4</artifactId>
            <version>4.1</version>
        </dependency>

代码如下:

public class TestApache {

    public static String[] attr1 = new String[]{"A", "B", "C", "D", "E", "F", null};
    public static String[] attr2 = new String[]{"1", "2", "3", "D", "E", "F", null};
    public static List<String> list1 = Arrays.asList(attr1);
    public static List<String> list2 = Arrays.asList(attr2);

    public static void main(String[] args) {
        System.out.println("交集:" + CollectionUtils.intersection(list1, list2)); // 交集
        System.out.println("补集:" + CollectionUtils.disjunction(list1, list2)); // 补集
        System.out.println("并集:" + CollectionUtils.union(list1, list2)); // 并集
        System.out.println("list1的差集:" + CollectionUtils.subtract(list1, list2)); // list1的差集
        System.out.println("list2的差集:" + CollectionUtils.subtract(list2, list1)); // list2的差集
    }
}

输出结果如下:

交集:[null, D, E, F]
补集:[A, 1, B, 2, C, 3]
并集:[null, A, 1, B, 2, C, 3, D, E, F]
list1的差集:[A, B, C]
list2的差集:[1, 2, 3]

二、hutool工具包

导入依赖

        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.4.2</version>
        </dependency>

代码如下:

public class TestHutool {
    public static String[] attr1 = new String[]{"A", "B", "C", "D", "E", "F", null};
    public static String[] attr2 = new String[]{"1", "2", "3", "D", "E", "F", null};

    public static void main(String[] args) {
        ArrayList<String> list1 = new ArrayList<>(Arrays.asList(attr1));
        ArrayList<String> list2 = new ArrayList<>(Arrays.asList(attr2));

        System.out.println("交集:" + CollectionUtil.intersection(list1, list2)); // 交集
        System.out.println("补集:" + CollectionUtil.disjunction(list1, list2)); // 补集
        System.out.println("并集:" + CollectionUtil.union(list1, list2)); //并集
        System.out.println("list1的差集"+CollectionUtil.subtract(list1,list2));
        System.out.println("list2的差集"+CollectionUtil.subtract(list2,list1));
        System.out.println("list1的差集:" + CollectionUtil.subtractToList(list1, list2));
        System.out.println("list2的差集:" + CollectionUtil.subtractToList(list2, list1));
    }
}

输出结果如下:

交集:[null, D, E, F]
补集:[1, A, 2, B, 3, C]
并集:[null, 1, A, 2, B, 3, C, D, E, F]
list1的差集[A, B, C]
list2的差集[1, 2, 3]
list1的差集:[A, B, C]
list2的差集:[1, 2, 3]

注意:subtract()和subtractToList()作用一样,不过处理方式不同,使用subtract()时,参数不能是Arrays.asList()的结果,否则会报异常,因为Arrays.asList()返回的对象是Arrays.ArrayList,在方法实现里面调用的是AbstractList抽象类里面的removeAll()方法,该方法代码如下:

public abstract class AbstractList<E> extends AbstractCollection<E> implements List<E> {

    // ....

    public E remove(int index) {
        throw new UnsupportedOperationException();
    }

    // ....
}

三、stream方式

代码如下:

public class TestStream {

    public static String[] attr1 = new String[]{"A", "B", "C", "D", "E", "F", null};
    public static String[] attr2 = new String[]{"1", "2", "3", "D", "E", "F", null};
    static List<String> list1 = Arrays.asList(attr1);
    static List<String> list2 = Arrays.asList(attr2);

    public static void main(String[] args) {
        List<Object> intersection = list1.stream().filter(item -> list2.contains(item)).collect(Collectors.toList());
        System.out.println("交集:" + intersection);

        List<String> subtract1 = list1.stream().filter(s -> !list2.contains(s)).collect(Collectors.toList());
        System.out.println("集合list1的差集:" + subtract1);
        List<String> subtract2 = list2.stream().filter(s -> !list1.contains(s)).collect(Collectors.toList());
        System.out.println("集合list2的差集:" + subtract2);

        List<String> union1 = list1.parallelStream().collect(Collectors.toList());
        List<String> union2 = list2.parallelStream().collect(Collectors.toList());
        union1.addAll(union2);
        List<String> union3 = union1.stream().distinct().collect(Collectors.toList());
        System.out.println("并集:" + union3);
    }
}

结果:

交集:[D, E, F, null]
集合list1的差集:[A, B, C]
集合list2的差集:[1, 2, 3]
并集:[A, B, C, D, E, F, null, 1, 2, 3]

四、Collection接口中的方法

public class TestCollection {

    public static String[] attr1 = new String[]{"A", "B", "C", "D", "E", "F", null};
    public static String[] attr2 = new String[]{"1", "2", "3", "D", "E", "F", null};

    public static void main(String[] args) {
        ArrayList<String> list1 = new ArrayList<>(Arrays.asList(attr1));
        ArrayList<String> list2 = new ArrayList<>(Arrays.asList(attr2));
        list1.retainAll(list2);
        System.out.println("交集:" + list1);

        ArrayList<String> list3 = new ArrayList<>(Arrays.asList(attr1));
        ArrayList<String> list4 = new ArrayList<>(Arrays.asList(attr2));
        HashSet<Object> set = new HashSet<>();
        set.addAll(list3);
        set.addAll(list4);
        System.out.println("并集:" + set);

        ArrayList<String> list5 = new ArrayList<>(Arrays.asList(attr1));
        ArrayList<String> list6 = new ArrayList<>(Arrays.asList(attr2));
        list5.removeAll(list6);
        System.out.println("集合A的差集:" + list5);
        ArrayList<String> list7 = new ArrayList<>(Arrays.asList(attr1));
        ArrayList<String> list8 = new ArrayList<>(Arrays.asList(attr2));
        list8.removeAll(list7);
        System.out.println("集合B的差集:" + list8);
    }
}

输出结果:

交集:[D, E, F, null]
并集:[null, A, 1, B, 2, C, 3, D, E, F]
集合A的差集:[A, B, C]
集合B的差集:[1, 2, 3]

 

  • 16
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,以下是编写程序的步骤: 1. 首先定义两个集合seta和setb,可以使用Python中的set()函数来创建集合。 2. 输入seta和setb的元素,可以使用input()函数来获用户输入的值,并使用split()函数将输入的字符串转换为列表。 3. 计算seta和setb的交集,可以使用&运算符或intersection()函数。 4. 计算seta和setb的并集,可以使用|运算符或union()函数。 5. 计算seta和setb的差集,可以使用-运算符或difference()函数。 6. 最后将计算结果输出即可。 以下是示例代码: ```python # 定义集合seta和setb seta = set() setb = set() # 输入seta和setb的元素 seta_input = input("请输入集合seta的元素,以空格分隔:") seta_list = seta_input.split() seta = set(seta_list) setb_input = input("请输入集合setb的元素,以空格分隔:") setb_list = setb_input.split() setb = set(setb_list) # 计算交集 intersection = seta & setb print("seta和setb的交集为:", intersection) # 计算并集 union = seta | setb print("seta和setb的并集为:", union) # 计算差集 difference = seta - setb print("seta和setb的差集为:", difference) ``` 希望能对你有所帮助! ### 回答2: 编写程序,输入两个集合seta和setb,可以通过使用set类型来表示集合,set类型自带去重功能,这样就避免了集合中元素的重复出现。在C++语言中,set类型定义在<set>头文件中。 程序中先输入两个集合seta和setb,可以使用循环输入的方式,输入集合中的元素,输入完成之后,可以使用set类型的insert函数将元素插入到set中,注意set类型中的元素类型需要与程序中输入的元素类型一致。 接下来,可以分别求seta和setb的交集并集差集,具体步骤如下: 1. 求交集:使用set类型自带的intersection函数,将seta和setb的交集存储在一个新的set中,然后遍历输出该set中的所有元素。 2. 求并集:使用set类型自带的并集运算符“|”,将seta和setb的并集存储在一个新的set中,然后遍历输出该set中的所有元素。 3. 求差集seta-setb:使用set类型自带的差集运算符“-”,将seta与setb的差集存储在一个新的set中,然后遍历输出该set中的所有元素。 完整代码如下: ``` #include <iostream> #include <set> using namespace std; int main() { set<int> seta, setb; int n, m, x; // 输入seta cin >> n; while (n--) { cin >> x; seta.insert(x); } // 输入setb cin >> m; while (m--) { cin >> x; setb.insert(x); } // 求交集 set<int> intersect; set_intersection(seta.begin(), seta.end(), setb.begin(), setb.end(), inserter(intersect, intersect.begin())); cout << "Intersection: "; for (int i : intersect) cout << i << " "; cout << endl; // 求并集 set<int> uni; uni = seta | setb; cout << "Union: "; for (int i : uni) cout << i << " "; cout << endl; // 求差集seta-setb set<int> difference; difference = seta - setb; cout << "Difference: "; for (int i : difference) cout << i << " "; cout << endl; return 0; } ``` ### 回答3: 编写程序,输入两个集合seta和setb,可以使用Python语言中的set()函数进行集合的定义和操作。seta和setb可以通过输入数据进行定义,例如: seta = set(input("请输入集合A中的元素,以空格分隔:").split()) setb = set(input("请输入集合B中的元素,以空格分隔:").split()) 其中,split()函数可以将输入的字符串按照空格分隔为元素,然后通过set()函数将元素定义为集合。 接着,可以使用Python中的交集并集差集操作符来对集合进行操作。具体操作如下: 1. 交集操作:使用&符号来求集合交集 intersection = seta & setb print("集合A和B的交集为:", intersection) 2. 并集操作:使用|符号来求集合并集 union = seta | setb print("集合A和B的并集为:", union) 3. 差集操作:使用-符号来求集合差集 difference = seta - setb print("集合A与B的差集为:", difference) 以上代码可以将输入的集合进行求交集并集差集的操作,并输出相应的结果。 需要注意的是,输入的集合元素应当保证唯一性,即输入的每个元素都应该与集合中的其他元素不同,否则会影响集合的操作结果。同时,输入的元素应当合法,不应有格式错误或类型不一致等情况。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值