实现算法2.2的程序
来源:互联网 发布:交大医学院网络英语 编辑:程序博客网 时间:2024/04/29 21:20
// algo2-2.cpp 实现算法2.2的程序#include"c1.h"typedef int ElemType;#include"c2-1.h"#include"bo2-1.cpp"#include"func2-3.cpp" // 包括equal()、comp()、print()、print2()和print1()函数void MergeList(SqList La,SqList Lb,SqList &Lc) // 算法2.2{ // 已知线性表La和Lb中的数据元素按值非递减排列。// 归并La和Lb得到新的线性表Lc,Lc的数据元素也按值非递减排列int i=1,j=1,k=0;int La_len,Lb_len;ElemType ai,bj;InitList(Lc); // 创建空表LcLa_len=ListLength(La);Lb_len=ListLength(Lb);while(i<=La_len&&j<=Lb_len) // 表La和表Lb均非空{GetElem(La,i,ai);GetElem(Lb,j,bj);if(ai<=bj){ListInsert(Lc,++k,ai);++i;}else{ListInsert(Lc,++k,bj);++j;}} // 以下两个while循环只会有一个被执行while(i<=La_len) // 表La非空且表Lb空{GetElem(La,i++,ai);ListInsert(Lc,++k,ai);}while(j<=Lb_len) // 表Lb非空且表La空{GetElem(Lb,j++,bj);ListInsert(Lc,++k,bj);}}void main(){SqList La,Lb,Lc;int j,a[4]={3,5,8,11},b[7]={2,6,8,9,11,15,20};InitList(La); // 创建空表Lafor(j=1;j<=4;j++) // 在表La中插入4个元素ListInsert(La,j,a[j-1]);printf("La= "); // 输出表La的内容ListTraverse(La,print1);InitList(Lb); // 创建空表Lbfor(j=1;j<=7;j++) // 在表Lb中插入7个元素ListInsert(Lb,j,b[j-1]);printf("Lb= "); // 输出表Lb的内容ListTraverse(Lb,print1);MergeList(La,Lb,Lc);printf("Lc= "); // 输出表Lc的内容ListTraverse(Lc,print1);}
运行的结果如下:
/*La= 3 5 8 11Lb= 2 6 8 9 11 15 20Lc= 2 3 5 6 8 8 9 11 11 15 20*/
0 0
- 实现算法2.2的程序
- 实现算法2.2的程序
- 实现算法2.2的程序
- 用单链表结构实现算法2.2的程序
- 用单链表结构实现算法2.2的程序
- Dinic算法的程序实现
- 实现算法2.1的程序
- 实现算法2.3的程序
- 实现算法2.4的程序
- 实现算法2.17的程序
- 实现算法2.17的程序
- 实现算法2.4的程序
- 实现算法2.3的程序
- 实现算法2.1的程序
- CRC的算法分析和程序实现
- Gossip数学问题算法的程序实现
- 实现算法2.11、2.12的程序
- 实现算法2.20、2.21的程序
- windows7 64bit下mvn命令后提示‘cmd’不是内部或外部命令,也不是可执行程序或批处理文件
- 实现算法2.2的程序
- LeetCode-First Missing Positive
- POJ 1751 Highways
- [LeetCode]—Word Search
- 实现算法2.2的程序
- 【DP】POJ 1252 完全背包
- C# 获取文件名及扩展名
- autorelease为什么不能用
- [Python] 发送email的几种方式
- 使用dom4j实现xml的增查删改
- 解密.net
- Memory Model
- 实现算法2.1的程序