Java学习之训练---求数组的交集、并集以及只在A数组中出现的子串集合

要求

  • 设有两字串构成的集合,字符串内容值为
  • A:{a,b,c,d,e,f,g,in,off,about,get}
  • B:{f,g,a,come,get,go}
  • 求出:
  • (1)AB集合的交集。
  • (2)只在A集中出现的子串集合。
  • (3)AB集合的并集。

代码

package day01;

import java.util.Arrays;
import java.util.List;

public class Demo03 {
    public static void main(String[] args) {
        //创建字符串数组,并赋值
        String[] arr1 = {"a","b","c","d","e","f","g","in","off","about","get"};
        String[] arr2 = {"f","g","a","come","get","go"};

        //测试交集,调用交集方法
        String[] arr3 = intersect(arr1,arr2);
        System.out.print("AB集合的交集如下:");
        for(int i=0;i<arr3.length;i++) {//遍历输出结果字符串数组
            if(arr3[i] != null) {
                System.out.print(arr3[i]+" ");
            }
        }
        System.out.println();
        System.out.println("===================分隔线=======================");

        //测试只有A中有,调用method方法
        String[] arr4 = method(arr1,arr2);
        System.out.print("只在A集中出现的字串集合如下:");
        for(int i=0;i<arr4.length;i++) {//遍历输出结果字符串数组
            if(arr4[i] != null) {
                System.out.print(arr4[i]+" ");
            }
        }
        System.out.println();
        System.out.println("===================分隔线=======================");
        //测试并集,调用union方法
        String[] arr5 = union(arr1,arr2);
        System.out.print("AB集合的并集如下:");
        for(int i=0;i<arr5.length;i++) {//遍历输出结果字符串数组
            if(arr5[i] != null) {
                System.out.print(arr5[i]+" ");
            }
        }
    }


    //(1)AB集合的交集。
    public static String[] intersect(String[] a1,String[] a2) {
        String[] a3 = new String[10];//创建字符串数组对象    
                                     //(存在缺陷,不够灵活,不知道该数组中元素个数)
        int k = 0;
        for(int i=0;i<a1.length;i++) {
            for(int j=0;j<a2.length;j++) {
                if(a1[i].equals(a2[j])) {//判断两元素是否相同
                    a3[k] = a1[i];//相同则记录到新的数组中
                    k++;
                }
            }
        }
        return a3;
    }

    //(2)只在A集中出现的字串集合。  
    public static String[] method(String[] a1,String[] a2) {
        String[] a3 = new String[10];//创建字符串数组对象
        int k = 0;
        for(int i=0;i<a1.length;i++) {
            List<String> list = Arrays.asList(a2);//将字符串数组a2转换成list
            if(!list.contains(a1[i])) {//调用list的contains方法,判断list中是否含有某元素
                a3[k] = a1[i];//不含,则记录到新数组中
                k++;
            }
        }
        return a3;
    }

    //(3)AB集合的并集。
    public static String[] union(String[] a1,String[] a2) {
        String[] a3 = new String[20];//创建字符串数组对象
        System.arraycopy(a1, 0, a3, 0, a1.length);
        int k = a1.length;
        List<String> list = Arrays.asList(a1);
        for(int i=0;i<a2.length;i++) {
            if(!list.contains(a2[i])) {
                a3[k+1] = a2[i];
                k++;
            }
        }
        return a3;
    }
}

运行结果

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值