随笔-用ArrayList实现求交集/并集/差集

本文提供了一个集合操作的Java实现示例,包括并集、交集和差集的计算方法。通过具体的代码片段,展示了如何使用ArrayList进行集合运算,适用于初学者理解和实践集合的基本概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:a {1,2,3,4} ---- b {3,4,5,6}
  • 并集:{1,2,3,3,4,4,5,6}
  • 交集{3,4}
  • 差集:a与b的差集{1,2}
public class ArrayListDemo {
       /*
         * @Description : 本质为两个集合的合并
         * @param arrayList1
         * @param arrayList2
         * @return :   java.util.ArrayList
         * @exception :
         * @date :   2019/2/21 18:08
         */
    public static  ArrayList unionSet(ArrayList arrayList1, ArrayList arrayList2){
         arrayList1.addAll(arrayList2); //得到并集,有重复元素的并集

         return arrayList1;
    }

       /*
        * @Description : 存在交集方法一
        * @param arrayList1
        * @param arrayList2
        * @return :   java.util.ArrayList
        * @exception :
        * @date :   2019/2/21 18:27
        */
    public static  ArrayList intersection1(ArrayList arrayList1,ArrayList arrayList2){
        arrayList1.retainAll(arrayList2);
        //两个集合取交集并将交集元素赋值给arrayList1;
        // 如果arrayList1发生变化则返回true;但如果两个集合相同,返回false;
        return arrayList1;
    }
       /*
        * @Description : 存在交集方法二
        * @param arrayList1
        * @param arrayList2
        * @return :   java.util.ArrayList
        * @exception :
        * @date :   2019/2/21 18:27
        */
    public static  ArrayList intersection2(ArrayList arrayList1,ArrayList arrayList2){
        ArrayList arrayList=new ArrayList();
        for(int i=0 ; i < arrayList1.size() ;i++ ){
            if(arrayList2.contains(arrayList1.get(i))){
            //如果arrayList2包含arrayList1中的元素,那么此元素为交集元素;
                arrayList.add(arrayList1.get(i));
            }
        }
        return arrayList;
    }

        /*
         * @Description : 求差集方法一
         * @param arrayList1
         * @param arrayList2
         * @return :   java.util.ArrayList
         * @exception :  
         * @date :   2019/2/21 19:53
         */
    public static  ArrayList differenceSet1(ArrayList arrayList1,ArrayList arrayList2){
        
        ArrayList arrayList=new ArrayList();
        for (int i = 0; i <arrayList1.size() ; i++) {
            if(!arrayList2.contains(arrayList1.get(i))){
                //arrayList2不包含arrayList1的元素,那么就是arrayList1的特有元素
                arrayList.add(arrayList1.get(i));
            }
        }
        return arrayList;
    }
    
     /*
         * @Description : 求差集方法二
         * @param arrayList1
         * @param arrayList2
         * @return :   java.util.ArrayList
         * @exception :  
         * @date :   2019/2/21 19:53
         */
    public static  ArrayList differenceSet2(ArrayList arrayList1,ArrayList arrayList2){
       arrayList1.removeAll(arrayList2);
       //list1集合与list2集合先找到交集,然后在list1中删除交集 ,
       //然后将删除交集后的list1重新赋给list1
        return arrayList1;
    }
        
    public static void main(String[] args) {
        ArrayList<Integer> arrayList2 = new ArrayList<Integer>();
        ArrayList<Integer>  arrayList1=new ArrayList<>();
        //添加元素 boolean add(E e)
        arrayList1.add(1);
        arrayList1.add(2);
        arrayList1.add(3);
        arrayList1.add(4);
        arrayList1.add(3);
        arrayList2.add(4);
        arrayList2.add(5);
        arrayList2.add(6);
        System.out.println(unionSet(arrayList1,arrayList2));
        System.out.println(intersection(arrayList1,arrayList2));
        System.out.println(differenceSet(arrayList1,arrayList2));
   }
}
     
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值