c语言写报告抽象数据类型,数据结构(C语言版)第一章 抽象数据类型的表示与实现...

//文件名:Triplet.c

//因为C语言没有引用,所以用指针代替引用

//函数的头文件

#include

#include

//函数结果状态码

#define TRUE 1

#define FALSE 0

#define OK 1

#define ERROR 0

#define INFEASIBLE -1

#define OVERFLOW -2

//Status是函数的类型,其值是函数结果的状态码

typedef int Status;

//定义数据类型

typedef int ElemType;

typedef ElemType *Triplet;

//----------基本操作的函数原型说明----------

Status InitTriplet( Triplet *pT, ElemType v1, ElemType v2, ElemType v3);

//操作结果:构造了三元组T,元素e1,e2,e3分别被赋予参数v1,v2,v3的值

Status DestroyTriplet(Triplet *pT);

//操作结果:三元组T被销毁

ElemType Get(Triplet T,int i,ElemType e);

//初始条件:三元组T已经存在,1<=i<=3

//操作结果: 用e返回T的第i个元素的值

Status Put(Triplet T,int i,ElemType e);

//初始条件:三元组T已经存在,1<=i<=3

//操作结果:改变T的第i个元素为e

Status IsAscending(Triplet T);

//初始条件:三元组T已经存在

//操作结果:如果T的三个元素按升序排列,则返回1,否则返回0

Status IsDescending(Triplet T);

//初始条件:三元组T已经存在

//操作结果:如果T的三个元素按降序排列,则返回1,否则返回0

ElemType Max(Triplet T,ElemType e);

//初始条件:三元组T已经存在

//操作结果:用e返回三个元素中的最大值

ElemType Min(Triplet T,ElemType e);

//初始条件:三元组T已经存在

//操作结果:用e返回三个元素中的最小值

//----------基本操作的实现-----------------

Status InitTriplet( Triplet *pT, ElemType v1, ElemType v2, ElemType v3)

{

//构造三元组T,依次置T的三个元素初值为v1, v2, v3

*pT=(Triplet)malloc(3 * sizeof(ElemType));//分配三个元素的存储空间

if(!(*pT)) exit(OVERFLOW) ;//分配存储空间失败

(*pT)[0]=v1;

(*pT)[1]=v2;

(*pT)[2]=v3;

return OK;

}//InitTriplet

Status DestroyTriplet(Triplet *pT)

{

//销毁三元组

free(*pT);

*pT=NULL;

return OK;

}//DedtroyTriplet

ElemType Get(Triplet T,int i,ElemType e)

{

//1<=i<=3,用e返回T的第i个元素值

if(i<1 || i>3) return ERROR;

e=T[i-1];

return e;

}//Get

Status Put(Triplet T,int i,ElemType e)

{

//1<=i<=3,置T的第i个元素的值为e

if(i<1 || i>3) return ERROR;

T[i-1]=e;

return OK;

}//Put

Status IsAscending(Triplet T)

{

//如果T的3个元素按升序排列,则返回1,否则返回0

return(T[0]<=T[1] && T[1]<=T[2]);

}//IsAscending

Status IsDescending(Triplet T)

{

//如果T的3个元素按降序排列,则返回1,否则返回0

return(T[0]>=T[1] && T[1]>=T[2]);

}//IsDescending

ElemType Max(Triplet T,ElemType e)

{

e=(T[0]>=T[1])?((T[0]>=T[2])?T[0]:T[2])

:((T[1]>=T[2])?T[1]:T[2]);

return e;

}//Max

ElemType Min(Triplet T,ElemType e)

{

e=(T[0]<=T[1])?((T[0]<=T[2])?T[0]:T[2])

:((T[1]<=T[2])?T[1]:T[2]);

return e;

}//Max

//-----------------------测试主程序--------------------

//为测试,新增一个显示函数

Status Show(Triplet T)

{

int i;

ElemType e;

if(!T)//如果T已经销毁

{

printf("T 已经销毁。");

}

else

{

for(i=1;i<=3;i++)

printf("T的第%d个元素值为:%d/n",i,Get(T,i,e));

}

}

int main()

{

Triplet T;

int i;

ElemType v1,v2,v3;

ElemType e;

//测试三元组的初始化函数 InitTriplet

printf("请输入三个整数,作为三元组的三个元素:/n");

scanf("%d%d%d",&v1,&v2,&v3);

InitTriplet(&T,v1,v2,v3);

//测试Get

Show(T);

//测试Put

printf("修改三元组的第二个元素的值:/n");

scanf("%d",&v2);

Put(T,2,v2);

Show(T);

//测试 IsAscending

if(IsAscending(T))

printf("T 是升序序列/n");

else

printf("T 不是升序序列/n");

//测试 IsDescending

if(IsDescending(T))

printf("T 是降序序列/n");

else

printf("T 不是降序序列/n");

//测试Max

e=Max(T,e);

printf("三元组中最大的元素是%d/n",e);

//测试Min

e=Min(T,e);

printf("三元组中最小的元素是%d/n",e);

//测试 DestroyTriplet

DestroyTriplet(&T);

Show(T);

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 本演示程序中,集合元素限定为数字,大小由用户输入。集合中数字顺序不限,且一旦出现重复字符或非法字符,程序能自动滤去。输出的运算结果中将不含重复数字或非法字符,且按照从小到大的顺序输出。<br>2. 演示程序以用户和计算机的对话方式执行,即在计算机上显示“提示信息”之后,由用户在键盘上输入演示程序中规定的运算命令;相应的数据输入和运算结果显示在其后。<br>3. 程序执行的命令包括:<br>(1)构造集合1;(2)构造集合2;(3)判断某数是否为集合元素;(4)添加元素;(5)删除元素;(6)求并集(存入集合1中);(7)求交集(存入集合3中);(8)输出集合1;(9)输出集合2;(0)退出。<br>“构造集合1”和“构造集合2”时,需以整型数字形式键入集合元素。<br><br>为实现上述程序功能,以线性链表表示集合。为此,需要两个抽象数据类型:线性表和集合。<br>1. 线性表的抽象数据类型定义为:<br> ADT LinkList{<br> 数据对象:D={ | IntSet,i=1,2,…,n,n 0}<br> 数据关系:R1={< , >| , D, < ,i=2,…,n}<br> 基本操作:<br> InitList(*L)<br> 操作结果:构造一个空的线性链表L。<br> IsElement(*L,e)<br> 初始条件:线性表L已存在。<br> 操作结果:若e是L的数据元素,返回1,否则返回0。<br> Append(*L,e)<br> 初始条件:线性表已存在。<br> 操作结果:按照由大到小的顺序往线性表里插入元素e,不允许重复元素。<br> Delete(*L,e)<br> 初始条件:线性表已存在。<br> 操作结果:在L中删除元素e。<br> }ADT LinkList<br>2. 集合的抽象数据类型定义为:<br> ADT LinkSet {<br> 数据对象:D={ | IntSet,i=1,2,…,n,n 0}<br> 数据关系:R1={}<br> 基本操作:<br> CreatSet(*L)<br> 初始条件:s为整型数组。<br> 操作结果:生成一个由s中数字构成的集合。<br> Union(*S1,*S2)<br> 初始条件:集合S1和S2存在。<br> 操作结果:生成一个由S1和S2的并集构成的集合,返回到S1。<br> Intersection (*S1,*S2)<br> 初始条件:集合S1和S2存在。<br> 操作结果:生成一个由S1和S2的交集构成的集合,返回到S1。<br> PrintSet (*S)<br> 初始条件:集合S已存在。<br> 操作结果:依次显示集合S中的全部元素。<br> }ADT LinkSet<br><br><br>带菜单<br>Turbo c 3.0编

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值