数据结构-顺序表查找插入与删除

ID:20894852

大小:63.50 KB

页数:4页

时间:2018-10-17

数据结构-顺序表查找插入与删除_第1页
数据结构-顺序表查找插入与删除_第2页
数据结构-顺序表查找插入与删除_第3页
数据结构-顺序表查找插入与删除_第4页
资源描述:

《数据结构-顺序表查找插入与删除》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、一、上机实验的问题和要求:顺序表的查找、插入与删除。设计算法,实现线性结构上的顺序表的产生以及元素的查找、插入与删除。具体实现要求:1.从键盘输入10个整数,产生顺序表,并输入结点值。2.从键盘输入1个整数,在顺序表中查找该结点的位置。若找到,输出结点的位置;若找不到,则显示“找不到”。3.从键盘输入2个整数,一个表示欲插入的位置i,另一个表示欲插入的数值x,将x插入在对应位置上,输出顺序表所有结点值,观察输出结果。4.从键盘输入1个整数,表示欲删除结点的位置,输出顺序表所有结点值,观察输出结果。二、源程序及注释:#i

2、nclude#include/*顺序表的定义:*/#include#defineListSize100/*表空间大小可根据实际需要而定,这里假设为100*/typedefintDataType;/*DataType可以是任何相应的数据类型如int,float或char*/typedefstruct{DataTypedata[ListSize];/*向量data用于存放表结点*/intlength;/*当前的表长度*/}SeqList;voidmain(){S

3、eqListL;inti,x;intn=10;/*欲建立的顺序表长度*/L.length=0;voidCreateList(SeqList*L,intn);voidPrintList(SeqListL,intn);intLocateList(SeqListL,DataTypex);voidInsertList(SeqList*L,DataTypex,inti);voidDeleteList(SeqList*L,inti);CreateList(&L,n);/*建立顺序表*/PrintList(L,n);/*打印顺序表*

4、/printf("输入要查找的值:");scanf("%d",&x);i=LocateList(L,x);/*顺序表查找*/printf("输入要插入的位置:");scanf("%d",&i);printf("输入要插入的元素:");scanf("%d",&x);4InsertList(&L,x,i);/*顺序表插入*/PrintList(L,n);/*打印顺序表*/printf("输入要删除的位置:");scanf("%d",&i);DeleteList(&L,i);/*顺序表删除*/PrintList(L,n);/

5、*打印顺序表*/}/*顺序表的建立:*/voidCreateList(SeqList*L,intn){inti;for(i=0;idata[i]);L->length=n;}/*顺序表的打印:*/voidPrintList(SeqListL,intn){inti;for(i=0;i

6、length&&L.data[i]!=x)++i;if(i

7、

8、i>L->length+1){printf("插入位置非法");exit(0);4}if(L->length>=ListSize){printf("表空间溢出,退出运行");exit(0);}for(j=L->length-1;j>=i-1;j--)L->dat

9、a[j+1]=L->data[j];L->data[i-1]=x;L->length++;}/*顺序表的删除:*/voidDeleteList(SeqList*L,inti){intj;if(L->length==0){printf("现行表为空,退出运行");exit(0);}if(i<1

10、

11、i>L->length){printf("删除位置非法");exit(0);}for(j=i;j<=L->length-1;j++)L->data[j-1]=L->data[j];L->length--;}4三、运行输出

12、结果:四、调试和运行程序过程中产生的问题及采取的措施:4

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
正文描述:

《数据结构-顺序表查找插入与删除》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、一、上机实验的问题和要求:顺序表的查找、插入与删除。设计算法,实现线性结构上的顺序表的产生以及元素的查找、插入与删除。具体实现要求:1.从键盘输入10个整数,产生顺序表,并输入结点值。2.从键盘输入1个整数,在顺序表中查找该结点的位置。若找到,输出结点的位置;若找不到,则显示“找不到”。3.从键盘输入2个整数,一个表示欲插入的位置i,另一个表示欲插入的数值x,将x插入在对应位置上,输出顺序表所有结点值,观察输出结果。4.从键盘输入1个整数,表示欲删除结点的位置,输出顺序表所有结点值,观察输出结果。二、源程序及注释:#i

2、nclude#include/*顺序表的定义:*/#include#defineListSize100/*表空间大小可根据实际需要而定,这里假设为100*/typedefintDataType;/*DataType可以是任何相应的数据类型如int,float或char*/typedefstruct{DataTypedata[ListSize];/*向量data用于存放表结点*/intlength;/*当前的表长度*/}SeqList;voidmain(){S

3、eqListL;inti,x;intn=10;/*欲建立的顺序表长度*/L.length=0;voidCreateList(SeqList*L,intn);voidPrintList(SeqListL,intn);intLocateList(SeqListL,DataTypex);voidInsertList(SeqList*L,DataTypex,inti);voidDeleteList(SeqList*L,inti);CreateList(&L,n);/*建立顺序表*/PrintList(L,n);/*打印顺序表*

4、/printf("输入要查找的值:");scanf("%d",&x);i=LocateList(L,x);/*顺序表查找*/printf("输入要插入的位置:");scanf("%d",&i);printf("输入要插入的元素:");scanf("%d",&x);4InsertList(&L,x,i);/*顺序表插入*/PrintList(L,n);/*打印顺序表*/printf("输入要删除的位置:");scanf("%d",&i);DeleteList(&L,i);/*顺序表删除*/PrintList(L,n);/

5、*打印顺序表*/}/*顺序表的建立:*/voidCreateList(SeqList*L,intn){inti;for(i=0;idata[i]);L->length=n;}/*顺序表的打印:*/voidPrintList(SeqListL,intn){inti;for(i=0;i

6、length&&L.data[i]!=x)++i;if(i

7、

8、i>L->length+1){printf("插入位置非法");exit(0);4}if(L->length>=ListSize){printf("表空间溢出,退出运行");exit(0);}for(j=L->length-1;j>=i-1;j--)L->dat

9、a[j+1]=L->data[j];L->data[i-1]=x;L->length++;}/*顺序表的删除:*/voidDeleteList(SeqList*L,inti){intj;if(L->length==0){printf("现行表为空,退出运行");exit(0);}if(i<1

10、

11、i>L->length){printf("删除位置非法");exit(0);}for(j=i;j<=L->length-1;j++)L->data[j-1]=L->data[j];L->length--;}4三、运行输出

12、结果:四、调试和运行程序过程中产生的问题及采取的措施:4

显示全部收起
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。
关闭