|
|
- /* algo2-3.c 实现算法2.7的程序 */
- #include"c1.h"
- typedef int ElemType;
- #include"c2-1.h"
- #include"bo2-1.c"
- void MergeList(SqList La,SqList Lb,SqList *Lc) /* 算法2.7 */
- { /* 已知顺序线性表La和Lb的元素按值非递减排列。 */
- /* 归并La和Lb得到新的顺序线性表Lc,Lc的元素也按值非递减排列 */
- ElemType *pa,*pa_last,*pb,*pb_last,*pc;
- pa=La.elem;
- pb=Lb.elem;
- (*Lc).listsize=(*Lc).length=La.length+Lb.length;/*不用InitList()创建空表Lc */
- pc=(*Lc).elem=(ElemType *)malloc((*Lc).listsize*sizeof(ElemType));
- if(!(*Lc).elem) /* 存储分配失败 */
- exit(OVERFLOW);
- pa_last=La.elem+La.length-1;
- pb_last=Lb.elem+Lb.length-1;
- while(pa<=pa_last&&pb<=pb_last) /* 表La和表Lb均非空 */
- { /* 归并 */
- if(*pa<=*pb)
- *pc++=*pa++;
- else
- *pc++=*pb++;
- }
- while(pa<=pa_last) /* 表La非空且表Lb空 */
- *pc++=*pa++; /* 插入La的剩余元素 */
- while(pb<=pb_last) /* 表Lb非空且表La空 */
- *pc++=*pb++; /* 插入Lb的剩余元素 */
- }
- void print(ElemType *c)
- {
- printf("%d ",*c);
- }
- void main()
- {
- SqList La,Lb,Lc;
- int j;
- InitList(&La); /* 创建空表La */
- for(j=1;j<=5;j++) /* 在表La中插入5个元素 */
- ListInsert(&La,j,j);
- printf("La= "); /* 输出表La的内容 */
- ListTraverse(La,print);
- InitList(&Lb); /* 创建空表Lb */
- for(j=1;j<=5;j++) /* 在表Lb中插入5个元素 */
- ListInsert(&Lb,j,2*j);
- printf("Lb= "); /* 输出表Lb的内容 */
- ListTraverse(Lb,print);
- MergeList(La,Lb,&Lc);
- printf("Lc= "); /* 输出表Lc的内容 */
- ListTraverse(Lc,print);
- }
复制代码
|
|