




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、、实验目的1、学习线性表的顺序表示和实现,会进行顺序表的插入、删除、合并2、学习线性表的链式表示和实现,会进行链表的插入、删除、合并二、实验内容1、编程实现:(1)在顺序表ajcniydu的第三个位置插入 p。(2)删除顺序表ajcniydu第三 个位置的元素。2、编程实现将顺序表 acdijtuy和cfklns合并。3、编程实现:(1)在链表asdfghjkl的第四个位置插入 z。(2)删除顺序表asdfghjkl第四个 位置兀索。4、编程实现两个有序链表adfi和cefi的合并。三、实验步骤1.+2.代码:#include<stdio.h>#include<malloc.
2、h>typedef char ElemType;typedef structElemType *elem;int length;int listsize;SqList;/定义结构体void InitList(SqList &L)L.elem=(ElemType*)malloc(10*sizeof(ElemType);L.length=0;L.listsize=10;/初始化void CreateList(SqList &L,int n)printf("输入字符串:");int i=0;for(i;i<n;i+)scanf("%c&quo
3、t;,&L.elemi);L.length+;"/赋值void Show(SqList L)int i=0;printf("字符串:");for(i;i<L.length;i+)printf("%c",L.elemi);printf("n");/显示int ListInsert(SqList &L, int i, ElemType e)ElemType *p;if (i < 1 | i > L.length+1)printf("插入位置不合法! n");elseElemT
4、ype *q = &(L.elemi-1);for (p = &(L.elemL.length-1); p>=q; -p) *(p+1) = *p;*q = e;+L.length;"/插入int ListDelete(SqList &L,int i)if(i > L.length|i<=0)printf("位置不合法n");elseint j = i-1;for( j;j<L.length;j+)L.elemj = L.elemj+1;L.length-;"/删除void Mergelist(SqList
5、 La,SqList Lb,SqList &Lc)ElemType *pa,*pb,*pc,*pa_last,*pb_last;pa = La.elem;pb = Lb.elem;pa_last = pa + La.length - 1;pb_last = pb + Lb.length - 1;Lc.listsize = Lc.length = La.length + Lb.length;pc = Lc.elem = (ElemType *)malloc(Lc.length*sizeof(ElemType);while(pa <= pa_last && pb &l
6、t;= pb_last)if(*pa >= *pb)* pc+ = *pa+;else* pc+ = *pb+;while(pa <= pa_last)* pc+ = *pa+;while(pb <= pb_last)* pc+ = *pb+;/合并int main()SqList La;InitList(La);CreateList(La,8);ElemType e;int i;printf("输入插入位置及字符:");scanf("%d %c",&i,&e);ListInsert(La,i,e);Show(La);p
7、rintf("n");flush(stdin);SqList Lb;InitList(Lb);CreateList(Lb,8);Show(Lb);printf("输入删除位置:");int j;scanf("%d",&j);ListDelete(Lb,j);Show(Lb);printf("n");fflush(stdin);SqList L1,L2,L3;InitList(LI);InitList(L2);CreateList(L1,8);Show(L1);fflush(stdin);CreateList
8、(L2,6);Show(L2);Mergelist(L1,L2,L3);Show(L3);D:C-languageCJ 1 .exe输入字符串:ajcniydu输入插入位置及字符:3 p字符串:ajpcniydu输入字符串:ajcniydu字符串:ajcniydu输入删除位置:3字符串:ajniydu输入字符串:acdijtuy输入字符串:cfklns合并为:字符串:cfklnsacdijtuyProcess returned 0 (0x0) execution time : 29.412 sPress any key to continue.3.+4.代码:#include<stdio
9、.h>#include<malloc.h> typedef char ElemType;typedef struct LNodechar a;ElemType data;struct LNode *next;LNode,*LinkList;/ 定义结构体int count = 0;void Createlist(LinkList &L,int n)printf("输入字符串:");L = ( LinkList )malloc( sizeof(LNode);L -> next = NULL;int i;LinkList p = ( LinkLi
10、st)malloc( sizeof(LNode);L = p;for( i = 0;i < n;i+)LinkList q = ( LinkList )malloc( sizeof(LNode);scanf("%c",&q -> a);q -> next = NULL;专业 word可编辑p = q;count +;"/创建链表void Show(LinkList L)LinkList p = ( LinkList )malloc( sizeof(LNode);p = L -> next;printf("字符串为:&quo
11、t;);while( p )printf("%c",p -> a);p = p -> next;printf("n");/输出链表int ListInsert( LinkList &L,int n,char K)if( L ->next = NULL)printf("链表为空! n");return 0;else if(n > count + 1)printf("插入位置不合法! n");return 0;elseLinkList p = ( LinkList)malloc( siz
12、eof (LNode);if( n = 1)p -> a = K;专业 word可编辑p -> next = L -> next;L -> next = p;else if( n = count + 1)p = L -> next;while( p -> next )p = p -> next;LinkList q = ( LinkList )malloc( sizeof (LNode);p -> next = q;q -> a = K;q -> next = NULL;elseint i;p = L;for( i = 1;i <
13、; n;i+)p = p -> next;LinkList q = ( LinkList )malloc( sizeof (LNode);q -> a = K;q -> next = p -> next;p -> next = q;count +;/插入int ListDelete( LinkList &L,int n)if( L -> next = NULL)printf("链表为空! n");return 0;else if( n > count )printf("删除位置不合法! n");retur
14、n 0;elseLinkList p = ( LinkList )malloc( sizeof (LNode);p = L -> next;if( n = 1 )L -> next = p -> next;free(p);elseint i;for( i = 1;i < n - 1;i+)p = p -> next;if( n = count )p -> next = NULL;elseLinkList q = ( LinkList )malloc( sizeof (LNode);q = p -> next;p -> next = q ->
15、 next;free(q);删除void MergeList(LinkList &La, LinkList &Lb, LinkList &Lc) LinkList pa, pb, pc;pa = La->next; pb = Lb->next;Lc = pc = La;while (pa && pb) if (pa->data <= pb->data) pc->next = pa; pc = pa; pa = pa->next;else pc->next = pb;pc = pb; pb = pb->
16、next; pc->next = pa ? pa : pb;free(Lb);"/合并int main()LinkList L1;Createlist(L1,9);Show(L1);char b;int i;printf("输入插入位置和插入元素:");scanf("%d %c",&i,&b);ListInsert(L1,i,b);Show(L1);fflush(stdin);printf("n");LinkList L2;Createlist(L2,9);Show(L2);int j;printf(&
17、quot;输入删除元素的位置:");scanf("%d",&j);ListDelete(L2,j);Show(L2);flush(stdin);printf("n");LinkList La;printf("输入需合并的两组字符串! n");Createlist(La,4);Show(La);flush(stdin);LinkList Lb;Createlist(Lb,4);Show(Lb);LinkList Lc;MergeList(La,Lb,Lc);Show(Lc);return 0;D:C-languageCJ 1.exe输入字符串:asdfghjkl字符串为:asdfghjkl匾又插入彳立置粕插入元素:4 z 字符串为:asdzfghjkl输入字符串:asdfghjkl字符串为:asdfghjkl 金入
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 保险基本原则试题及答案
- 职业药师药一试题及答案
- 花艺作品评估标准及试题及答案
- 农业职业经理人考试自我管理能力的提升与实现试题及答案
- 抗病性植物的研究试题及答案
- 苯系物考试题及答案
- 花卉设计的基本原则及试题及答案
- 推动学校内涵式发展的具体举措
- 重庆长江黄金游轮有限公司招聘考试真题2024
- 把握趋势2024年福建事业单位考试试题及答案
- 保健院业务部门绩效考核实施方案(试行)及质量控制指标
- 马鞍山东站站房工程指导性施工组织设计
- DB52∕T 1559-2021 朱砂 工艺品-行业标准
- 电力电缆工程施工作业危险点辨识及预控措施手册
- 精神障碍检查与诊断试题
- 研究生英语综合教程(下)1-10单元全部答案及解析
- 中医护理原则和方法
- 光伏电站验收申请及验收报告样板
- flow10.1教程DFM
- 【演练方案】特种设备事故(压力容器)应急预案演练记录
- 换流站控制保护软件Accel简介
评论
0/150
提交评论