常熟理工oracle实验十一_《数据结构与算法》实验报告册-常熟理工学院

1

实验一

顺序表与链表

一、实验目的

1

、掌握线性表中元素的前驱、后续的概念。

2

、掌握顺序表与链表的建立、插入元素、删除表中某元素的算法。

3

、对线性表相应算法的时间复杂度进行分析。

4

、理解顺序表、链表数据结构的特点(优缺点)

二、实验内容和要求

1

、阅读下面程序,在横线处填写函数的基本功能。并运行程序,写出结果。

#include

#include

#define ERROR 0

#define OK 1

#define INIT_SIZE 5     /*

初始分配的顺序表长度

*/

#define INCREM 5        /*

溢出时,顺序表长度的增量

*/

typedef  int ElemType;  /*

定义表元素的类型

*/

typedef struct Sqlist{

ElemType *slist;      /*

存储空间的基地址

*/

int length;           /*

顺序表的当前长度

*/

int listsize;         /*

当前分配的存储空间

*/

}Sqlist;

/* main2-1.c 检验bo2-1.c的主程序 */ #include"c1.h" typedef int ElemType; #include"c2-1.h" #include"bo2-1.h" #include"func2-3.h" Status sq(ElemType c1,ElemType c2) { /* 数据元素判定函数(平方关系),LocateElem()调用的函数 */ if(c1==c2*c2) return TRUE; else return FALSE; } void dbl(ElemType *c) { /* ListTraverse()调用的另一函数(元素值加倍) */ *c*=2; } void main() { SqList L; ElemType e,e0; Status i; int j,k; ///建立线性表 printf("1、建立线性表:\n"); InitList(&L); printf("初始化L后:L.elem=%u L.length=%d L.listsize=%d\n",L.elem,L.length,L.listsize); for(j=1;j<=5;j++) i=ListInsert(&L,1,j); printf("在L的表头依次插入1~5后:*L.elem="); ///遍历线性表 printf("2、遍历线性表:\n"); for(j=1;j<=5;j++) printf("%d ",*(L.elem+j-1)); printf("\n"); printf("L.elem=%u L.length=%d L.listsize=%d ",L.elem,L.length,L.listsize); i=ListEmpty(L); printf("L是否空:i=%d(1:是 0:否)\n",i); ///清空线性表 printf("3、清空线性表:\n"); ClearList(&L); printf("清空L后:L.elem=%u L.length=%d L.listsize=%d ",L.elem,L.length,L.listsize); i=ListEmpty(L); printf("L是否空:i=%d(1:是 0:否)\n",i); ///重新插入 printf("4、重新插入、重新遍历:\n"); for(j=1;j<=10;j++) ListInsert(&L,j,j); printf("在L的表尾依次插入1~10后:*L.elem="); //重新遍历 for(j=1;j<=10;j++) printf("%d ",*(L.elem+j-1)); printf("\n"); printf("L.elem=%u L.length=%d L.listsize=%d\n",L.elem,L.length,L.listsize); ListInsert(&L,1,0); printf("在L的表头插入0后:*L.elem="); for(j=1;j<=ListLength(L);j++) /* ListLength(L)为元素个数 */ printf("%d ",*(L.elem+j-1)); printf("\n"); printf("L.elem=%u(有可能改变) L.length=%d(改变) L.listsize=%d(改变)\n",L.elem,L.length,L.listsize); //查询第5个元素的值 printf("5、查询第5个元素的值:\n"); GetElem(L,5,&e); printf("第5个元素的值为:%d\n",e); //查询线性表中是否有“10,11”值 printf("6、查询线性表中是否有10或11值:\n"); for(j=10;j<=11;j++) { k=LocateElem(L,j,equal); if(k) /* k不为0,表明有符合条件的元素,且其位序为k */ printf("第%d个元素的值为%d\n",k,j); else printf("没有值为%d的元素\n",j); } //查询线性表中是否有“10,11”值 printf("6、查询线性表中是否有9或16值:\n"); for(j=3;j<=4;j++) { k=LocateElem(L,j,sq); if(k) /* k不为0,表明有符合条件的元素,且其位序为k */ printf("第%d个元素的值为%d的平方\n",k,j); else printf("没有值为%d的平方的元素\n",j); } //测试线性表前两个元素的前驱 printf("7、测试线性表前两个元素的前驱:\n"); for(j=1;j<=2;j++) /* 测试头两个数据 */ { GetElem(L,j,&e0); /* 把第j个数据赋给e0 */ i=PriorElem(L,e0,&e); /* 求e0的前驱 */ if(i==INFEASIBLE) printf("元素%d无前驱\n",e0); else printf("元素%d的前驱为:%d\n",e0,e); } //测试线性表后两个元素的后继 printf("8、测试线性表后两个元素的后继:\n"); for(j=ListLength(L)-1;j<=ListLength(L);j++) /* 最后两个数据 */ { GetElem(L,j,&e0); /* 把第j个数据赋给e0 */ i=NextElem(L,e0,&e); /* 求e0的后继 */ if(i==INFEASIBLE) printf("元素%d无后继\n",e0); else printf("元素%d的后继为:%d\n",e0,e); } k=ListLength(L); /* k为表长 */ //删除表尾数据 printf("9、删除表尾数据:\n"); for(j=k+1;j>=k;j--) { i=ListDelete(&L,j,&e); /* 删除第j个数据 */ if(i==ERROR) printf("删除第%d个元素失败\n",j); else printf("删除第%d个元素成功,其值为:%d\n",j,e); } printf("依次输出L的元素:"); ListTraverse(L,print1); /* 依次对元素调用print1(),输出元素的值 */ printf("L的元素值加倍后:"); ListTraverse(L,dbl); /* 依次对元素调用dbl(),元素值乘2 */ ListTraverse(L,print1); //销毁线性表 printf("10、销毁线性表:\n"); DestroyList(&L); printf("销毁L后:L.elem=%u L.length=%d L.listsize=%d\n",L.elem,L.length,L.listsize); }
实验一 顺序表与链表 一、实验目的 1、掌握线性表中元素的前驱、后续的概念。 2、掌握顺序表与链表的建立、插入元素、删除表中某元素的算法。 3、对线性表相应算法的时间复杂度进行分析。 4、理解顺序表、链表数据结构的特点(优缺点)。 二、实验预习 说明以下概念 1、线性表: 2、顺序表: 3、链表: 三、实验内容和要求 1、阅读下面程序,在横线填写函数基本功能。并运行程序写出结果。 #include<stdio.h> #include<malloc.h> #define ERROR 0 #define OK 1 #define INIT_SIZE 5 /*初始分配的顺序表长度*/ #define INCREM 5 /*溢出时,顺序表长度的增量*/ typedef int ElemType; /*定义表元素的类型*/ typedef struct Sqlist{ ElemType *slist; /*存储空间的基地址*/ int length; /*顺序表的当前长度*/ int listsize; /*当前分配的存储空间*/ }Sqlist; int InitList_sq(Sqlist *L); /*初始化顺序表L,并将其长度设为0*/ int CreateList_sq(Sqlist *L,int n); /* 构造顺序表长度为n */ int ListInsert_sq(Sqlist *L,int i,ElemType e);/* 在顺序线性表L中第i个元素之前插入新的元素*/ int PrintList_sq(Sqlist *L); /*输出顺序表的元素*/ int ListDelete_sq(Sqlist *L,int i); /*删除第i个元素*/ int ListLocate(Sqlist *L,ElemType e); /*查找值为e的元素*/ int InitList_sq(Sqlist *L){ L->slist=(ElemType*)malloc(INIT_SIZE*sizeof(ElemType)); if(!L->slist) return ERROR; L->length=0; L->listsize=INIT_SIZE; return OK; }/*InitList*/ int CreateList_sq(Sqlist *L,int n){ ElemType e; int i; for(i=0;i<n;i++){ printf("input data %d",i+1); scanf("%d",&e); if(!ListInsert_sq(L,i+1,e)) return ERROR; } return OK; }/*CreateList*/ /*输出顺序表中的元素*/ int PrintList_sq(Sqlist *L){ int i; for(i=1;i<=L->length;i++) printf("%5d",L->slist[i-1]); return OK; }/*PrintList*/ int ListInsert_sq(Sqlist *L,int i,ElemType e){ int k; if(i<1||i>L->length+1) return ERROR; if(L->length>=L->listsize){ L->slist=(ElemType*)realloc(L->slist, (INIT_SIZE+INCREM)*sizeof(ElemType)); if(!L->slist) return ERROR; L->listsize+=INCREM; } for(k=L->length-1;k>=i-1;k--){ L->slist[k+1]= L->slist[k]; } L->slist[i-1]=e; L->length++; return OK; }/*ListInsert*/ /*在顺序表中删除第i个元素*/ int ListDelete_sq(Sqlist *L,int i){ if((i<1)||(i>L->length)) return ERROR; for(p=i-1;plength-1;p++) { L->slist[p]=L->slist[p+1]; } L->length--; return OK; } } /*在顺序表中查找指定值元素,返回其序号*/ int ListLocate(Sqlist *L,ElemType e){ } int main(){ Sqlist sl; int n,m,k; printf("please input n:"); /*输入顺序表的元素个数*/ scanf("%d",&n); if(n>0){ printf("\n1-Create Sqlist:\n"); InitList_sq(&sl); CreateList_sq(&sl,n); printf("\n2-Print Sqlist:\n"); PrintList_sq(&sl); printf("\nplease input insert location and data:(location,data)\n"); scanf("%d,%d",&m,&k); ListInsert_sq(&sl,m,k); printf("\n3-Print Sqlist:\n"); PrintList_sq(&sl); printf("\n"); } else printf("ERROR"); return 0; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值