用java编程实现集合的交、并、差和补运算

 

 

一、实验目的

掌握集合的交、并、差和补运算,并且使用计算机编程实现。

二、实验内容

通过编程实现求给定集合A和B的并集C(C=A∪B)、交集C(C=A∩B)、差集C(C=A-B)、补集~C=E-C的运算。

三、实验要求

C、C++或Jave语言编程实现

四、实验原理

1、根据交集的定义:C={x | x∈A∧x∈B},我们将集合A的各个元素与集合B的元素进行比较,若在集合B中存在某个元素和集合A中一元素相等,则将该元素送入交集C之中。

2、并集的定义为:C={x|x∈A∨x∈B},所以,只要将集合A与B合在一起就得到了并集C。但是,在一个集合中,同样的元素没必要出现两次或两次以上,所以,在将集合A送入并集C后,应将集合B中与A中相同的元素删除,再将集合B送入并集C之中。

3、差集C的定义:差集C={x|x∈A∧xB},即对于集合A中的元素ai,若不存在bj∈B(j=1,2,…..,m),使得ai=bj,则ai ∈差集C。

4、补集C的定义:~C=E-C={ x|x∈E∧xC }

五、实验过程

源代码

package cn.sal.lisan;

import java.util.HashSet;

import java.util.Set;

import java.util.Scanner;

public class Bingjiao {

    public static void main(String[] args) {

        Set<Integer> result = new HashSet<Integer>();

        Set<Integer> A = new HashSet<Integer>();         

        Set<Integer> B = new HashSet<Integer>();

        Set<Integer> E=new HashSet<Integer>();

        //以上是为了为四个集合开辟内存空间,方便后续赋值

        

        

        System.out.println("请先输入A,B,E每个集合的元素个数,然后依次输入集合中的元素");

        Scanner scanner=new Scanner(System.in);//获取控制台输入

        int x=scanner.nextInt();//获取A集合的元素个数

        int y=scanner.nextInt();//获取B集合元素个数

        int z=scanner.nextInt();//获取E集合元素个数

      //  int[] a=new int[x];

        for(int i=0;i<x;i++)

        {

         int i1=scanner.nextInt();

         A.add(i1);

        }

        //为A集合赋值

        for(int j=0;j<y;j++)

        {

         int j1=scanner.nextInt();

         B.add(j1);

        }

        //为B集合赋值

        for(int k=0;k<z;k++)

        {

         int k1=scanner.nextInt();

         E.add(k1);

        }

        System.out.println("E ="+E.toString());

        System.out.println("A = "+A.toString());

        System.out.println("B = "+B.toString());

         

        result.clear();//清除result中的元素

        result.addAll(A);//将A集合中的元素放入result中

        result.retainAll(B);//去除A中的所有不在B中的元素

        System.out.println("交集 = " + result);

         

        result.clear();

        result.addAll(A);

        result.removeAll(B);//清除A中所有属于B的元素

        System.out.println("差集 = "+result);

         

        result.clear();

        result.addAll(A);

        result.addAll(B);//把A,B中的元素都加入进去,而且set中不会有重复的元素

        System.out.println("并集 = " + result);

        

        

        result.clear();

        result.addAll(E);

        result.removeAll(A);//跟差集一样

        System.out.println("补集 ="+result);

    }

}

实验结果

请先输入A,B,E每个集合的元素个数,然后依次输入集合中的元素

2 4 5

1 2

1 3 4 5

1 2 3 4 5

E =[1, 2, 3, 4, 5]

A = [1, 2]

B = [1, 3, 4, 5]

AB交集 = [1]

AB差集 = [2]

AB并集 = [1, 2, 3, 4, 5]

AB补集 =[3, 4, 5]

 

 

  • 实验总结

总结:因为这次离散实验可以用java写,而java中HashSet类恰好有add()  remove()等方法直接用来计算集合的并集,交集,差集,所以本次实验就使用java语言来完成了,这次实验利用了set类的特性,即不会出现相同的元素,和集合定义相符合,该题的思路是,利用scanner类获取用户的输入值,然后利用set类的add方法,将用户输入的集合元素全部放入相应的集合中,此后,具体到求交集并集差集时,先引入第三个变量result作存储(引入第三方是为了不改变已定义好的集合的值),在计算交集时,先用addall方法把A集合全部放入result中,然后result调用retainAll(B)方法,保留result中存在B中的元素,同样,计算并集时,用addAll方法,把A和B集合都放在result中,利用set不允许集合出现重复元素特性,可得到A和B的并集,在求差集时,调用removeAll方法,可除去A中存在B中的元素,在求补集时,也是利用差集思想,去除E中存在A中的元素。

 

转载于:https://www.cnblogs.com/chmusk/p/11078936.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/248899.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

node.js项目中常量的配置 - 个人文章 - SegmentFault 思否

在项目中&#xff0c;我们常将一些常量信息做成配置项&#xff0c;如&#xff0c;数据库的链接配置&#xff0c;业务错误代码配资等等。 我们通过两种方式可以解决该问题。 系统环境变量的方式 配置文件的方式 下边&#xff0c;将以这两方面进行展开。 1. 系统环境变量 No…

MySQL create table语法中的key与index的区别

在create table的语句中&#xff0c;key和index混淆在一起&#xff0c;官方手册中的解释是这样&#xff1a; KEY is normally a synonym for INDEX. The key attribute PRIMARY KEY can also be specified as just KEY when given in a column definition. This was implemente…

蓝桥杯 历届试题 九宫重排 (bfs+康托展开去重优化)

Description 如下面第一个图的九宫格中&#xff0c;放着 1~8 的数字卡片&#xff0c;还有一个格子空着。与空格子相邻的格子中的卡片可以移动到空格中。经过若干次移动&#xff0c;可以形成第二个图所示的局面。我们把第一个图的局面记为&#xff1a;12345678.把第二个图的局面…

DIV或者DIV里面的图片水平与垂直居中的方法 - 站住,别跑 - 博客园

DIV或者DIV里面的图片水平与垂直居中的方法 <div class“box”><img /> </div> 水平居中的常用方式&#xff1a; text-align:center ——这可以实现子元素字体&#xff0c;图片的水平居中。 margin:0 auto —— 这是针对块元素的水平居中方法 垂直居中的常…

spring boot的多环境部署

需求&#xff1a;不同的环境有不同的开关属性&#xff0c;比如开发系统&#xff0c;需要关闭短信&#xff0c;微信的通知功能。而演示环境&#xff0c;线上环境则需要打开这些配置。 那么&#xff0c;如何做到呢&#xff1f;---》在properties.application配置 需要在resources…

mybatis之动态SQL操作之查询

1&#xff09; 查询条件不确定&#xff0c;需要根据情况产生SQL语法&#xff0c;这种情况叫动态SQL /*** 持久层* author AdminTC*/ public class StudentDao {/*** 动态SQL--查询*/public List<Student> dynaSQLwithSelect(String name,Double sal) throws Exception{S…

设置图片元素上下垂直居中的7种css样式_赵一鸣博客

设置图片元素上下垂直居中的7种css样式 阅读(9548) 2018-07-15 14:13:34 图片、文字左右居中很简单&#xff0c;只需要以下代码&#xff1a; 1 text-align:center; 文字上下居中也很简单&#xff0c;假设外部div元素的高度是100px&#xff0c;那么&#xff1a; 1 line-heig…

zap+日志分级分文件+按时间切割日志整合demo

实现功能 info debug 级别的日志输出到 /path/log/demo.log     warn error .... 级别的日志输出到 /path/log/demo_error.log     日志自动按小时分割 最多保留7天的日志 依赖的第三方包github地址 https://github.com/uber-go/zap https://github.com/lestrrat-go/fi…

day36 Pyhton 网络编程03

一.内容回顾 socket通常也称作"套接字"&#xff0c;用于描述IP地址和端口&#xff0c;是一个通信链的句柄&#xff0c;应用程序通常通过"套接字"向网络发出请求或者应答网络请求。 socket起源于Unix&#xff0c;而Unix/Linux基本哲学之一就是“一切皆文件”…

在webpack中使用eslint配置(详细教程)-js教程-PHP中文网

本篇文章主要介绍了webpack引入eslint配置详解&#xff0c;现在分享给大家&#xff0c;也给大家做个参考。 webpack中eslint使用 首先&#xff0c;要使webpack支持eslint&#xff0c;就要要安装 eslint-loader &#xff0c;命令如下: 1 npm install --save-dev eslint-loader 在…

创建一个属于自己的博客

1、安装 node.js wget https://nodejs.org/dist/v10.15.3/node-v10.15.3-linux-x64.tar.xz tar -xf node-v10.15.3-linux-x64.tar.xz -C /home/ 解压到/home、目录下 mv node-v10.15.3-linux-x64/ node vim /etc/profile #配置环境变量 export PATH/home/node/bin:$PATH export…

Redis是什么?

Redis is an open source, BSD licensed, advanced key-value store. It is often referred to as a data structure server since keys can contain strings, hashes, lists, sets and sorted sets. redis是开源,BSD许可,高级的key-value存储系统. 可以用来存储字符串,哈希结构…

Vue中定义全局变量与常量的各种方式详解_vue.js_脚本之家

前言 本文主要跟大家介绍了关于Vue定义全局变量与常量的相关内容&#xff0c;分享出来供大家参考学习&#xff0c;下面话不多说了&#xff0c;来一起看看详细的介绍&#xff1a; 我想要定义一个变量, 在项目的任何地方都可以访问到, 不需要每一次使用的时候, 都引入. 尝试1:…

oracle 数据库 锁

首先你要知道表锁住了是不是正常锁&#xff1f;因为任何DML语句都会对表加锁。 你要先查一下是那个会话那个sql锁住了表&#xff0c;有可能这是正常业务需求&#xff0c;不建议随便KILL session&#xff0c;如果这个锁表是正常业务你把session kill掉了会影响业务的。建议先查原…

推荐21个顶级的Vue UI库! – TalkingData‘s Blog

推荐21个顶级的Vue UI库&#xff01; 最近&#xff0c;随着“星球大战”&#xff08;指 GitHub 的 Star 数量大比拼&#xff09;的爆发&#xff0c;Vue.js 在 GitHub 上的 Star 数超过了 React。虽然 NPM 的下载量仍然落后于 React&#xff0c;但 Vue.js 的受欢迎程度似乎在持续…

后缀数组水题两道

BZOJ1031:倍长&#xff0c;建sa&#xff0c;跑一边把sa值小于等于长度的后缀第n个字母输出BZOJ4278:直接把串合并起来建一个sa就可以了&#xff0c;然后直接分组贪心 转载于:https://www.cnblogs.com/dream-maker-yk/p/10068915.html

js获取页面的各种高度与宽度

document.body.scrollTop等属性可以获取页面滚动距离等&#xff0c;但是此类属性在xhtml标准网页或者更简单的说是带<!DOCTYPE ..>标签的页面里得到的结果是0&#xff0c; 所以一般为了兼容性都这样写 document.documentElement.scrollTop || document.body.scrollTop;以…

MAC终端下常用Git命令 - 某个人 - 博客园

送给新手的简单命令操作、远程Git和local的同步实现流程&#xff1a; 1、把git上的代码clone到本地 $ git clone http:xxxx(地址&#xff0c;可以http也可以ssh) 2、clone到本地以后、使用branch -a 查看远程所有分支 $ git branch -a 3、如若你有分支&#xff1a;master…

2019河北省大学生程序设计竞赛(重现赛)B 题 -Icebound and Sequence ( 等比数列求和的快速幂取模)...

题目链接&#xff1a;https://ac.nowcoder.com/acm/contest/903/B 题意&#xff1a; 给你 q,n,p,求 q1q2...qn 的和 模 p。 思路&#xff1a;一开始不会做&#xff0c;后面查了下发现有个等比数列求和的快速幂公式&#xff0c;附上链接https://www.cnblogs.com/yuiffy/p/380917…

centos 升级curl版本

1、安装repo rpm -Uvh http://www.city-fan.org/ftp/contrib/yum-repo/rhel6/x86_64/city-fan.org-release-2-1.rhel6.noarch.rpm 2、查看该 repo 包含的 curl 版本 yum.repos.d]# yum --showduplicates list curl --disablerepo"*" --enablerepo"city*"L…