数据结构实验1_第1页
数据结构实验1_第2页
数据结构实验1_第3页
数据结构实验1_第4页
数据结构实验1_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论