【离散数学】集合

2024-04-19 03:20
文章标签 离散数学 集合

本文主要是介绍【离散数学】集合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、什么是集合

集合是由指定范围内的满足给定条件的所有对象聚集在一起构成。每一个对象称为这个集合的元素。 集合中的元素是无序、不同的。

1.集合的数学符号

通常情况:

  • 使用带或不带下标的大写英文字母表示集合:A、B……A1、B1……
  • 使用带或不带下标的小写英文字母表示元素:a、b……a1、b1……

常用集合:

  1. 自然数集合N
  2. 正数集合Z
  3. 有理数集合Q
  4. 实数集合R
  5. ……

2.集合定义

如果a是集合A中的元素,称a属于A,记为a∈A。 反之a不属于A,记为a∉A。

3.集合的表示

枚举法

A = {a, b, c,……}

叙述法

P = {x| P(x)}

文氏图

文氏图表示集合

4.集合的基数

基数表示集合中元素的数量,符号为|集合|

A = {a,b,c}

A的基数|A|为3。

二、特殊集合

  • 空集Ø,Ø={x|x ≠ x}
  • 全集U或E
  • 幂集,P(A) = {x|x⊆A},A的幂集是A的全部不同子集构成的集合

三、集合间的关系

外延性原理:有A、B两个集合,当且仅当他们的元素完全相同,记为A = B。

包含:A中含有B中的全部元素称为A包含B,记B⊆A。否则记为B⊄A(这里应该是前面的包含符号画一条斜杠,找不到这个符号了,就用了非真包含)

真包含:在包含条件下满足A ≠ B,则 B⊂A。

A = B <=> A⊆B 并且 B⊆A

四、集合的运算

下图橘色区域为A⋃B的结果 

并

下图橘色区域为A⋂B的结果 

交

下图橘色区域为A的补集 

补

下图橘色区域为A-B 

差

对称差

下图橘色区域为A⊖B (我看的b站电子科大教程ppt里圈中间的符号是+,但是我百度到的符号中间是-) 

对称差

五、集合的运算定律

幂等律A⋃A=A A⋂A=A
交换律

A⋃B=B⋃A

A⋂B=B⋂A

结合律

A⋃B⋃C=A⋃(B⋃C)

A⋂B⋂C=A⋂(B⋂C)

同一律A⋃Ø=A A⋂U=A
零律A⋂Ø=Ø A⋃U=U
分配律

A⋃(B⋂C)=(A⋃B)⋂(A⋃C)

A⋃(B⋂C)=(A⋂B)⋃(A⋂C)

吸收律

A⋃(A⋂B)=A

A⋂(A⋃B)=A

矛盾论和排中律

A⋂A补=Ø

A⋃A补=U

双重否定律A补的补=A
德摩根律

(A⋃B)的补=A补⋂B补

(A⋂B)的补=A补⋃B补

六、可数集合和不可数集合

等势:若集合A和B之间存在一种--对应的关系,则A和B是等势的,记为A~B

可数集合:与自然数集合N等势的集合称为可数集合,该集合的基数记为ℵ₀(阿列夫零)

不可数集合开区间(0,1)称为不可数集合,凡是与开区间(0,1)等势的集合,称为不可数集合,这类集合的基数记为ℵ(阿列夫)

这篇关于【离散数学】集合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/916515

相关文章

基于Redis有序集合实现滑动窗口限流的步骤

《基于Redis有序集合实现滑动窗口限流的步骤》滑动窗口算法是一种基于时间窗口的限流算法,通过动态地滑动窗口,可以动态调整限流的速率,Redis有序集合可以用来实现滑动窗口限流,本文介绍基于Redis... 滑动窗口算法是一种基于时间窗口的限流算法,它将时间划分为若干个固定大小的窗口,每个窗口内记录了该时间

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

Java基础回顾系列-第六天-Java集合

Java基础回顾系列-第六天-Java集合 集合概述数组的弊端集合框架的优点Java集合关系图集合框架体系图java.util.Collection接口 List集合java.util.List接口java.util.ArrayListjava.util.LinkedListjava.util.Vector Set集合java.util.Set接口java.util.HashSetjava

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(

java集合的概述

集合就是一个容器,我们可以把多个对象放入的容器中。就像水杯(假设容量可以不断扩大)一样,你可以往水杯中不断地添加水,既然是水杯,你就不能往里添加沙子,也就是说集合中添加的对象必须是同一个类型的(引用类型,而不能是基本类型)。 看到集合的介绍会让我们的想起数组,那么集合和数组有什么区别呢? 首先,数组的大小是固定的,而集合理论上大小是不限的。 其次,数组既可以存储基本数据类型的数据,也可以存储

hutool 集合相关交集、差集

开发过程中会遇到集合之间的对比之类的需求,之前经常会自己写个工具类来实现,目前hutool可以帮助我们解决很多问题,接下来我们就来实践下。 相关jar包 <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>RELEASE</version><scope>compile</sco

Java8中的Stream,让集合操作酸爽起来

简介 java8也出来好久了,接口默认方法,lambda表达式,函数式接口,Date API等特性还是有必要去了解一下。比如在项目中经常用到集合,遍历集合可以试下lambda表达式,经常还要对集合进行过滤和排序,Stream就派上用场了。用习惯了,不得不说真的很好用。 Stream作为java8的新特性,基于lambda表达式,是对集合对象功能的增强,它专注于对集合对象进行各种高效、便利的聚合

算法练习小技巧之有序集合--套路详细解析带例题(leetcode)

前言:         本文详细讲解Python中的有序集合SortedList和C++中的有序集合multiset的用法,配合leetcode的例题来展示实际的用处。(本人水平不够,还无法讲解有序集合的实现方法,只会用)         觉得有帮助或者写的不错可以点个赞,后面也有几道我找出来的题目可以用这个方法快速解决的         (感觉有点水) 目录 有序集合用法讲解:

Java中集合类Set、List和Map的区别

Java中的集合包括三大类,它们是Set、List和Map,它们都处于java.util包中,Set、List和Map都是接口,它们有各自的实现类。Set的实现类主要有HashSet和TreeSet,List的实现类主要有ArrayList,Map的实现类主要有HashMap和TreeMap。那么它们有什么区别呢? Set中的对象不按特定方式排序,并且没有重复对象。但它的有些实现类能对集合中的对

复杂SQL集合(不断收集中)

1.一道SQL语句面试题,关于group by 表内容: 2005-05-09 胜 2005-05-09 胜 2005-05-09 负 2005-05-09 负 2005-05-10 胜 2005-05-10 负 2005-05-10 负 如果要生成下列结果, 该如何写sql语句?             胜 负 2005-05-09 2 2 2005-05-10 1 2 --------