版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上离散实验报告 专业:数学与应用数学 班级: 学号:姓名:张鼎珩日期:2011.06.23实验内容:实验一 真值计算实验二 两个集合运算实验三 关系闭包计算实验四 关系与函数进行试验:实验一 真值计算一、 实验目的熟悉联结词合取、析取、条件和双条件的概念,编程求其真值。二、 实验内容(1) 求任意一个命题公式的真值表:从键盘输入两个命题 P 和 Q 的真值,求它们的合取、析取、蕴含和等价的真值(2) 利用真值表求任意一个命题公式的主范式(3) 利用真值表进行逻辑推理三实验程序:#include<stdio.h>/*标准输入输出头文件*/#include<
2、;stdlib.h>/*该文件包含了的C语言标准库函数的定义*/#include<string.h>/*字符串数组的函数定义的头文件*/#include<conio.h>/*通用输入输出库*/#include<math.h>#define N 50 void jisuan();void zhenzhibiao();void panduan(int bN,int f);int tkh (char szN, char ccuN, int icuN, int h0);int fkh (char szN, char ccuN, int icuN, int h0
3、);main()int a1;start: doprintf(" 1.求P、Q的合取、析取、条件和双条件的真值n 2.求任意一个命题公式的真值表,并根据真值表求主范式n 3.退出n");printf("n选择功能选项:");fflush(stdin);/*清空输入缓冲区,通常是为了确保不影响后面的数据读取*/scanf("%d",&a1);switch(a1)/*switch语句实现选择功能*/ case 1:system("cls");jisuan();break;/*功能A*/case 2:system
4、("cls");fflush(stdin);zhenzhibiao();break;/*功能BC*/case 3:system("exit");exit(0);/*结束整个程序的运行*/default:system("cls");goto start;/*控制流转移到start处*/ while(1);void jisuan()/*功能A*/char p,q,t,ch;int p1,q1;dostart:fflush(stdin);printf("请输入P和Q的真值(T或F):");scanf("%c,%
5、c",&p,&q);if(p='F'|p='f'|p='T'|p='t')&&(q='F'|q='f'|q='T'|q='t')if(p='F'|p='f')/*赋值*/p1=0;elsep1=1;if(q='F'|q='f')q1=0;elseq1=1;if(p1|q1)/*计算*/t='T'elset='F'printf(&qu
6、ot;P析取Q为:%cn",t);if(p1&q1)t='T'elset='F'printf("P和取Q为:%cn",t);if(!p1)|q1)t='T'elset='F'printf("P条件Q为:%cn",t);if(p1=q1)t='T'elset='F'printf("P双条件Q为:%cn",t);elseprintf("请按正确格式输入!n");goto start;printf("
7、;是否继续输入?Y/N");fflush(stdin);ch=getch();system("cls");while(ch!='n'&&ch!='N');void zhenzhibiao()/*功能BC*/int i1,i2,d=1,icuN,kh=0,jg,j=0,h0;int bj=0,hqN,h=0,x=0,xqN;char szN,ccuN,sz0N;hq0=-1;xq0=-1;printf("请输入一个合法的命题公式(可含与或非及括号):n");gets(sz);strcpy(sz0,s
8、z);for(i1=0;i1<strlen(sz);i1+)if(szi1=')' | szi1='(')kh+;if(szi1>='a' && szi1<='z' | szi1>='A' && szi1<='Z') for(i2=0;i2<j;i2+) /*判断并储存变量*/if(ccui2=szi1)d=0;if(d=1)ccuj=szi1;j+;d=1; printf("n该式子中的变量个数为:%dn",j
9、);h0=j; printf("n输出真值表如下:n n"); for(i1=0;i1<h0;i1+)printf(" %c ",ccui1); printf(" ");puts(sz);printf("n"); for(i1=0;i1<j;i1+) /*先将所有的变量赋值为零*/icui1=0;for(i2=0;i2<j;i2+)printf(" %d ",icui2);jg=tkh(sz,ccu,icu,h0); if(jg=0)hqh+=bj;else xqx+=bj;
10、printf(" -> %dn",jg);strcpy(sz,sz0); for(i1=0;i1<(int)pow(2,j)-1;i1+)+bj;panduan(icu,0); /*赋值变量*/jg=tkh(sz,ccu,icu,h0); if(jg=0)hqh+=bj;else xqx+=bj; strcpy(sz,sz0); /*恢复被修改的数组*/for(i2=0;i2<j;i2+)printf(" %d ",icui2);printf(" -> %dn",jg); if(hq0=-1)printf(&q
11、uot;n该命题公式不存在主合取范式。n");else printf("n该命题公式的主合取范式:nt");for(i1=0;i1<h;i1+)printf("M(%d) ",hqi1); if(xq0=-1)printf("n该命题公式不存在主析取范式。n");elseprintf("nn该命题公式的主析取范式:nt");for(i1=0;i1<x;i1+)printf("m(%d) ",xqi1);printf("n"); getch();syste
12、m("cls");fflush(stdin);void panduan(int bN,int f) /* 二进制赋值*/ int i;i=f;if(bf=0)bf=1;elsebf=0;panduan(b,+i); int tkh (char szN,char ccuN,int icuN,int h0)int i,j,h,s,kh=0,wzN,a; char xs1N,ckhN; /*xs1用来保存括号内的字符 ckh用来保存括号*/s=strlen(sz);for(i=0;i<s;i+)if(szi='(' | szi=')')wzk
13、h=i;ckhkh=szi;kh+;if(kh=0)return fkh(sz,ccu,icu,h0);elsefor(i=0;i<kh;i+)if(ckhi=')')break;for(j=wzi-1+1,h=0;j<wzi;j+,h+) xs1h=szj; xs1h='0'a=fkh(xs1,ccu,icu,h0);if(a=1)szwzi-1=1;elseszwzi-1=-2;for(j=wzi-1+1;j<s+wzi-1-wzi;j+)szj=szj+wzi-wzi-1;szj='0' return tkh(sz,ccu
14、,icu,h0);int fkh(char szN,char ccuN,int icuN,int h0)int i,h=0,j=0,j1=0,j2=0,j3=0,i1,i2,p1=-1,p2=-1,s;char dtN;s=strlen(sz);if(s=1)if(sz0=-2)return 0;elsereturn 1; /*1 就是sz0的值*/else for(i=0;i<s-j;i+) /*先处理非*/if(szi='!') for(i1=0;i1<h0;i1+)if(szi+1=ccui1)p1=icui1;if(szi+1=-2)p1=0; if(p1=
15、-1)p1=szi+1; dtj+2=!p1;szi=j+2;j+;p1=0;for(i1=i+1;i1<s-j;i1+)szi1=szi1+1;p1=-1; j1=j; for(i=0;i<s-j1-2*j2;i+) /*处理与*/if(szi='&') for(i1=0;i1<h0;i1+) if(szi-1=ccui1)p1=icui1;if(szi+1=ccui1)p2=icui1;for(i2=2;i2<j+2;i2+) if(szi-1=i2) p1=dti2; if(szi+1=i2)p2=dti2;if(szi-1=-2)p1=0
16、; if(szi+1=-2)p2=0;if(p1=-1) p1=(int)(szi-1);if(p2=-1)p2=(int)(szi+1); dtj+2=p1 && p2;szi-1=j+2;j+;j2+;p1=-1;p2=-1; for(i1=i;i1<s-j1-2*j2;i1+)szi1=szi1+2;i=i-1;for(i=0;i<s-j1-2*j2-2*j3;i+) /* 处理或*/ if(szi='|')for(i1=0;i1<h0;i1+) if(szi-1=ccui1)p1=icui1;if(szi+1=ccui1)p2=icui
17、1;for(i2=2;i2<j+2;i2+) if(szi-1=i2) p1=dti2;if(szi+1=i2)p2=dti2;if(szi-1=-2)p1=0; if(szi+1=-2)p2=0;if(p1=-1)p1=szi-1;if(p2=-1)p2=szi+1;dtj+2=p1 | p2;szi-1=j+2;j+;j3+;p1=-1;p2=-1; for(i1=i;i1<s-j1-2*j2-2*j3;i1+)szi1=szi1+2;i-; return dtj+1;运行结果:实验二 两个集合运算一、 实验目的集合论是一切数学的基础,也是计算机科学不可或缺的,在数据结构,数据
18、库理论,开关理论,自动机理论和可计算理论等领域都有广泛的应用。集合的运算规则是集合论中的重要内容。通过该组实验,目的是让学生更加深刻地理解集合的概念和性质,并掌握集合的运算规则等。 二、 实验内容(1) 求任意两个集合的交集、并集、差集(2) 求任意一个集合的幂集(3) 求任意一个集合的所有m元子集三实验程序#include<stdio.h>#include<stdlib.h>typedef struct LinkList/定义结构体类型指针char data;struct LinkList*next;LinkList;void input(LinkList*head)
19、 /定义输入集合函数LinkList *p;char t;printf("输入数据,按回车键结束:");scanf("%c",&t);while(t!='n')p=(LinkList*)malloc(sizeof(struct LinkList);p->data=t;p->next=head->next;head->next=p;scanf("%c",&t);void output(LinkList*head)/定义输出集合函数LinkList *p;p=head->nex
20、t;while(p!=NULL)printf("%c ",p->data);p=p->next;printf("n");void Sort(LinkList *head)/定义排序函数 LinkList *p=head->next,*q,*r; if(p!=NULL) r=p->next; p->next=NULL; p=r; while(p!=NULL) r=p->next; q=head; while(q->next!=NULL&&q->next->data<p->da
21、ta) q=q->next; /在有序表中找插入*p的前驱结点*q p->next=q->next; /将*p插到*q之后 q->next=p; p=r; void AND(LinkList*head1,LinkList*head2,LinkList*head3)/定义集合的并集函数LinkList *p1,*p2,*p3;p1=head1->next;while(p1!=NULL)p3=(LinkList*)malloc(sizeof(struct LinkList);p3->data=p1->data;p3->next=head3->n
22、ext;head3->next=p3;p1=p1->next;p2=head2->next;while(p2!=NULL)p1=head1->next;while(p1!=NULL)&&(p1->data!=p2->data)p1=p1->next;if(p1=NULL)p3=(LinkList*)malloc(sizeof(struct LinkList);p3->data=p2->data;p3->next=head3->next;head3->next=p3;p2=p2->next;void O
23、R(LinkList*head1,LinkList*head2,LinkList*head3)/定义集合的交集函数LinkList*p1,*p2,*p3;p1=head1->next;while(p1!=NULL)p2=head2->next;while(p2!=NULL)&&(p2->data!=p1->data)p2=p2->next;if(p2!=NULL)&&(p2->data=p1->data)p3=(LinkList*)malloc(sizeof(struct LinkList);p3->data=p1
24、->data;p3->next=head3->next;head3->next=p3;p1=p1->next;void differ(LinkList*head1,LinkList*head2,LinkList*head3)/定义集合的差集函数LinkList*p1,*p2,*p3;p1=head1->next;while(p1!=NULL)p2=head2->next;while(p2!=NULL)&&(p2->data!=p1->data)p2=p2->next;if(p2=NULL)p3=(LinkList*)m
25、alloc(sizeof(struct LinkList);p3->data=p1->data;p3->next=head3->next;head3->next=p3;p1=p1->next;main()/主函数 int j;LinkList *head1,*head2,*head3;head1=(LinkList*)malloc(sizeof(struct LinkList);head1->next=NULL;head2=(LinkList*)malloc(sizeof(struct LinkList);head2->next=NULL;hea
26、d3=(LinkList*)malloc(sizeof(struct LinkList);head3->next=NULL;printf("请输入集合A:n");input(head1);/调用输入集合函数printf("请输入集合B:n");input(head2);/调用输入集合函数 /Sort(head1); /Sort(head2); / printf("有序集合A ");output(head1);printf("n"); / printf("有序集合B ");output(he
27、ad2);printf("n"); printf("请选择您要执行的操作:.求并集.求交集.求差集.退出n"); scanf("%d",&j); switch(j) case 1: printf("集合与集合的并集"); AND(head1,head2,head3);/调用并集函数 Sort(head3); output(head3); break; case 2: printf("集合与集合的交集"); OR(head1,head2,head3);/调用交集函数 Sort(head3)
28、; output(head3); break; case 3: printf("集合与集合的差集"); differ(head1,head2,head3);/调用差集函数 Sort(head3); output(head3); break; case 0: break; system("pause"); 运行结果:实验三 关系与函数一、 实验目的函数是集合论中的一个十分重要的概念通过该组实验,目的是让学生更加深刻地理解函数的概念和性质,并掌握函数性质的判定等。二、 实验内容判断任意一个关系是否为函数,若是函数,判定其是否为单射,满射或双射。三实验程序:#
29、include<stdio.h> #include<stdlib.h> #include<string.h>/此程序是用来证实A-B(A,B是集合)在函数f上是哪种函数的程序。 int main()int i,j;int anum,bnum,x,y,tt,aa1010;/anum,bnum分别表示A,B集合中元素的个数, /aa用来存储A集合中的内容 bool bb1010,flag1,flag2;/bbi用来表示B集合中有i元素,flag1用来表示 /是否为满射,flag2用来表示是否是单射 int bbnum1010;/用来记录有几个A中的元素可以推得B
30、bbnumi中的元素i memset(bb,false,sizeof(bb);memset(bbnum,0,sizeof(bbnum);scanf("%d%d",&anum,&bnum);for(i=1;i<=anum;i+)/输入A中元素 scanf("%d",&x);aai=x;for(i=1;i<=bnum;i+)/输入B中元素 scanf("%d",&x);bbx=true;for(i=1;i<=anum;i+)y=aai*5+1;/这里是对A中的元素进行函数运算,在程序中自己
31、设置,/你可以自己改比如改成x*x+8就可以写成5flag1=true;flag2=true;for(i=0;i<=1000;i+)/判断映射关系 if(bbi)if(bbnumi=0)flag1=false;elseif(bbnumi>1)flag2=false;if(flag1&&flag2)printf("双射n");elseif(flag1&&!flag2)printf("满射n");elseif(!flag1&&flag2)printf("单射n");else printf("不是函数n"); system("pause");四运行结果:实验四 关系闭包计算一、 实验目的关系是集合论中的一个十分重要的概念,关系性质的判定是集合论中的重要内容。通过该组实验,目的是让学生更加深刻地理解关系的概念和性质,并掌握关系性质的判定等。熟悉 Warshall 算法,掌握求关系的自反闭包、对称闭包和传递闭包的方法。二、 实验内容判断任意一个关系是否为自反关系,对称关系,传递关系和等价关系。若是等价关系,求出其
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年质量管理体系建立与实施指南
- 企业人力资源管理与企业绩效评估指南
- 商业购物中心无乐不造3活动策划方案
- 民航安全管理规范与流程(标准版)
- 物业管理公司服务标准与流程手册(标准版)
- 城市道路施工质量保证制度
- 车站设备维修保养制度
- DB61T 2084-2025农村水电站标识标志标线设置及设备着色规范
- 财务资金回收与坏账处理制度
- 办公室投诉与反馈处理制度
- 中国特色社会主义知识点总结中职高考政治一轮复习
- 企业管理的基础工作包括哪些内容
- 学校“1530”安全教育记录表(2024年秋季全学期)
- 铝合金门窗工程技术规范
- 食材配送服务方案投标文件(技术标)
- 室性心律失常
- 《2024消费者金融知识学习偏好及行业宣教洞察报告》
- 中国高血压防治指南(2024年修订版)解读课件
- 科研项目数据保护应急预案
- 2024年土地转租的合同范本
- 附件2:慢病管理中心评审实施细则2024年修订版
评论
0/150
提交评论