⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 algo2-1.cpp

📁 数据结构相关代码
💻 CPP
字号:
 // algo2-1.cpp 实现算法2.7的程序
 #include"c1.h"
 typedef int ElemType; // 定义ElemType为整型
 #include"c2-1.h" // 线性表的顺序存储结构
 #include"bo2-1.cpp" // 线性表顺序存储结构的基本操作
 #include"func2-2.cpp" // 包括equal()、comp()、print()、print1()和print2()函数
 void MergeList(SqList La,SqList Lb,SqList &Lc) // 算法2.7
 { // 已知顺序线性表La和Lb的元素按值非递减排列。
   // 归并La和Lb得到新的顺序线性表Lc,Lc的元素也按值非递减排列(不改变表La和表Lb)
   ElemType *pa,*pa_last,*pb,*pb_last,*pc;
   pa=La.elem; // pa指向表La的第1个元素
   pb=Lb.elem; // pb指向表Lb的第1个元素
   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; // pa_last指向表La的最后1个元素
   pb_last=Lb.elem+Lb.length-1; // pb_last指向表Lb的最后1个元素
   while(pa<=pa_last&&pb<=pb_last) // 表La和表Lb均有元素没有归并
   { // 归并
     if(*pa<=*pb) // 表La的当前元素不大于表Lb的当前元素
       *pc++=*pa++; // 将pa所指单元的值赋给pc所指单元后,pa和pc分别+1
     else
       *pc++=*pb++; // 将pb所指单元的值赋给pc所指单元后,pb和pc分别+1
   } // 以下两个while循环只会有一个被执行
   while(pa<=pa_last) // 表Lb中的元素全都归并
     *pc++=*pa++; // 插入La的剩余元素
   while(pb<=pb_last) // 表La中的元素全都归并
     *pc++=*pb++; // 插入Lb的剩余元素
 }

 void main()
 {
   SqList La,Lb,Lc;
   int j;
   InitList(La); // 创建空表La
   for(j=1;j<=5;j++) // 在表La中插入5个元素,依次为1、2、3、4、5
     ListInsert(La,j,j);
   printf("La= "); // 输出表La的内容
   ListTraverse(La,print1);
   InitList(Lb); // 创建空表Lb
   for(j=1;j<=5;j++) // 在表Lb中插入5个元素,依次为2、4、6、8、10
     ListInsert(Lb,j,2*j);
   printf("Lb= "); // 输出表Lb的内容
   ListTraverse(Lb,print1);
   MergeList(La,Lb,Lc); // 由按非递减排列的表La、Lb得到按非递减排列的表Lc
   printf("Lc= "); // 输出表Lc的内容
   ListTraverse(Lc,print1);
 }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -