用Python复习离散数学(一)
最近要复习离散数学,不想挂啊,但是又想编程,大家知道啦,程序员离不开代码啊,所用想边复习边写代码,所以就自己用代码去实现一下离散的知识点,当做复习,自知自己的Python很渣,也想借此巩固一下基础,哈哈,事不宜迟,开始吧!
1.集合
概念:集合是由指定范围内的某些特定对象聚集在一起构成的,元素就是集合中的每一个对象
怎么用python实现集合呢,这个我自定义了一个类,这个类中有一个构造方法,底层我用列表是存储集合中的元素,用add方法可以添加元素,show方法就可以展示元素
class MySet():
__num = 0 def __init__(self):
self.s = [] def show(self):
self.str = '{'
for x in self.s:
if x == self.s[self.__num - 1]:
self.str += x
else:
self.str += x + ', '
self.str += '}'
print self.str def add(self, element):
self.__num += 1
self.s.append(element)
测试一下:
s = MySet()
s.add('a')
s.add('b')
s.show() #结果
#{a, b}
这样好样就有点味道了,爽爽的,杠杠的。
1.1集合与集合的关系
在这个这里我们要明白集合的几个特定性,集合的无序性,MySet类可以符合,但是还有个互异性我们就解决,互异性就是不能出现相同的元素,所以我们的add方法要改造一下:
def add(self, element):
__flag = 0
for x in self.s:
if x == element:
__flag = 1
print '%s element is exist!' % element
if __flag == 0:
self.__num += 1
self.s.append(element)
这样就解决了元素的互异性
外延性原理:两个集合A和B相等,当且仅当它们有相同的元素,记为A=B,否则A与B不相等,记为A!=B
程序怎么实现呢,我首先向MySet类添加下列方法,length方法拿到集合的长度,get方法根据索引那元素的值,checkExist方法检查元素是否存在在改集合中,setEqual方法就是判断集合相等的核心方法。
def length(self):
return self.__num def get(self, index):
if index >= 0 and index < self.__num:
return self.s[index]
else:
print 'no exist' def checkExist(self, element):
for x in self.s:
if x == element:
return True
return False def setEqual(self, setTemp):
if self.__num == setTemp.length():
for x in range(setTemp.length()):
if self.checkExist(setTemp.get(x)):
continue
else:
return False
return True
else:
return False
测试一下:
s1 = MySet()
s1.add('a')
s1.add('b')
s2 = MySet()
s2.add('a')
s2.add('b')
print s1.setEqual(s2) #结果
#True
判断是否为子集,这个也就是包含关系,其实我很经常弄错谁包含谁的,所以现在要搞清楚了:如果B的每个元素都是A的元素,则成B是A的子集,也成称B被A包含,或者A包含B,就是大的包含小的,OK,理解了,然后就看看程序怎么实现,我们通过isSubset方法去实现判断:
def isSubset(self, setTemp):
for x in range(setTemp.length()):
if self.checkExist(setTemp.get(x)):
continue
else:
return False
return True
在集合中有一个非常特殊的集合,不含任何元素的集合,称为空集,谨记,空集是任何集合的子集,我们通过isEmptySet方法来判断这个集合是不是空集。
def isEmptySet(self):
if self.__num == 0:
return True
else:
return False
集合的运算:
并运算:
union方法及测试:
def union(self, setTemp):
newSet = MySet()
for x in self.s:
newSet.add(x)
for x in range(setTemp.length()):
if newSet.checkExist(setTemp.get(x)):
continue
else:
newSet.add(setTemp.get(x))
return newSet s1 = MySet()
s1.add('a')
s2 = MySet()
s2.add('b')
s2.add('a')
s2.add('c')
s3 = s1.union(s2)
s3.show()
交运算:
intersection方法的实现:
def intersection(self, setTemp):
newSet = MySet()
for x in range(setTemp.length()):
if self.checkExist(setTemp.get(x)):
newSet.add(setTemp.get(x))
return newSet
差运算:(A-B表示一个差集,集合中只有属于A自己独有的元素)
subtraction方法的实现:
def subtraction(self, setTemp):
newSet = MySet()
for x in self.s:
if setTemp.checkExist(x):
continue
else:
newSet.add(x)
return newSet
补运算:(首先要判断一下两者的关系是不是正确的,然后再去算补集)
complement方法的实现:
def complement(self, setTemp):
newSet = MySet()
if setTemp.isSubset(self):
for x in range(setTemp.length()):
if self.checkExist(setTemp.get(x)):
continue
else:
newSet.add(setTemp.get(x))
return newSet
else:
print 'error in relation'
return newSet
对称差运算:(对称差集就是两个集合的并集减去两个集合的交集,其实简单的说就是并集和交集的差集)
sysmmetric方法的实现:
def sysmmetric(self, setTemp):
newSet1 = self.union(setTemp)
newSet2 = self.intersection(setTemp)
return newSet1.subtraction(newSet2)
用Python复习离散数学(一)的更多相关文章
- 用Python复习离散数学(二)
这次复习的是计数问题,立刻走起吧! 1.乘法原理 如果一项工作需要t步完成的,第一步有n1种不同的选择,第二步有n2种不同的选择,……,第t步有nt中不同的选择,那么完成这项工作所有可能的选择种数为: ...
- 九九乘法表的python复习
九九开始的复习 这周复习之前的学的知识关于range函数,gormat函数,print的使用总结一下 从一个小例子开始,开始我的回顾吧, 大家都是从那个九九乘法表开始的数学之旅,从一一得一,开始了我们 ...
- Python 复习-1
#!/usr/bin/env python # -*- coding:utf-8 -*- # @Time : 2017/10/27 22:46 # @Author : lijunjiang # @Fi ...
- Python复习 一
Python回炉复习 1 变量 Python的变量和C语言的变量书写方式类似: 书写要求 python程序编写结构利用缩进表示,抛弃花括号: 结构 分支: if(条件语句1): 执行语句块 else ...
- 后端程序员之路 20、python复习
Welcome to Python.orghttps://www.python.org/ 怎么用最短时间高效而踏实地学习 Python? - 知乎https://www.zhihu.com/quest ...
- python复习
1.input和raw_input的区别 input假设输入的都是合法的python表达式,如输入字符串时候,要加上引号,而raw_input都会将所有的输入作为原始数据 2.原始字符串前面加上r,e ...
- Python复习笔记-字典和文件操作
抽时间回顾2年前自己做过的python工具,突然感觉不像自己写的,看来好久没用过python的字典和文件操作了,查询资料和网页,整理如下: 一.字典 键值对的集合(map) 字典是以大括号“{}”包围 ...
- python复习。知识点小记
1.对于单个字符的编码,Python提供了ord()函数获取字符的整数表示,chr()函数把编码转换为对应的字符: >>> ord('A') >>> ord('中' ...
- python复习1
比如常用的数学常数π就是一个常量.在Python中,通常用全部大写的变量名表示常量: Python支持多种数据类型,在计算机内部,可以把任何数据都看成一个“对象”,而变量就是在程序中用来指向这些数据对 ...
随机推荐
- 左右c++与java中国的垃圾问题的分析与解决
左右c++与java中国的垃圾问题的分析与解决 DionysosLai(906391500@qq.com) 2014/8/1 问题分析: 之所以会出现中文乱码问题,归根结底在于中文的编码与英文的编码 ...
- ABP领域层——实体
ABP领域层——实体 基于DDD的现代ASP.NET开发框架--ABP系列之10.ABP领域层——实体 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的 ...
- Tips & Tricks:Apache log4j简明教程(一)
Apache log4j的官方介绍是“log4j is a reliable, fast and flexible logging framework (APIs) written in Java, ...
- 第16章 观察者模式(Oberver Pattern)
原文 第16章 观察者模式(Oberver Pattern) 观察者模式 概述: 在软件构建过程中,我们需要为某些对象建立一种“通知依赖关系” ——一个对象(目标对象)的状态发生改变,所有的依 ...
- mac os x10.11.2系统eclipse无法读取环境变量的问题
eclipse调试Android自动化脚本的时候一直无法找到adb,遇到这么坑的问题,折腾死了,记录一下. mac os x10.11.2系统GUI程序(eclipse)无法读取~/.bash_pro ...
- linux_设置开机自启动程序脚本
设置开机自启动
- 去除win7 64位系统桌面图标小箭头
http://blog.csdn.net/pipisorry/article/details/24865195 在桌面新建一个文本文档 去除箭头.txt,把例如以下代码粘贴到文档中reg add &q ...
- 【百度地图API】批量地址解析与批量反地址解析(带商圈数据)
原文:[百度地图API]批量地址解析与批量反地址解析(带商圈数据) 摘要:因为地址解析的webserives方式还没有开通,所以先用JS版本的地址解析接口来批量获取地址解析数据吧,同时还能得到商圈的数 ...
- CSS3+HTML5特效1 - 上下滑动效果
先看看效果,把鼠标移上去看看. back front 1. 本实例需要以下元素: a. 外容器 box b. 内容器 border c. 默认显示内容 front d. 滑动内容 back 2. 外容 ...
- awk的实施例
1.使用split功能 name.url内容: 上海 http://trip.elong.com/shanghai/jingdian elong destination 云南 http ...