概述
合并链表
题目:
一直链表La和Lb最终的数据元素按非递减排列,将两表合并得到的新表的数据元素也按非递减排列。
1、
void MergeList(List La, List Lb, List &Lc) {
InitList(Lc); // 初始化表Lc
i = j = k = 1; // i,j,,k分别记录表La,Lb,Lc读取的位置
La_len = ListLength(La);Lb_len = ListLength(Lb);
while(i <= La_len && j <= Lb_len) {
// 表La,Lb均为非空,循环结束时,La与Lb至少有一个已全部读取
GetElem(La, i, ai);GetElem(Lb, j, bj);
if (ai <= bj) {
ListInsert(Lc, k++, ai);
i++;
}
else {
ListInsert(Lc, k++, bj);
j++;
}
}
// 若有剩余元素,直接将全部剩余元素按原顺序插入表Lc尾,两个循环必定指执行其中一个
while (i <= La_len) {
GetElem(La, i, ai);
ListInsert(Lc, k++, ai);
}
while (j <= Lb_len) {
GetElem(Lb, j, bj);
ListInsert(Lc, k++, bj);
}
}
2、递归
List MergeList(List L1, List L2) {
if (L1 == nullptr) {
return L2;
}
else if (L2 == nullptr) {
return L1;
}
else if (L1->data < L2->data) {
L1->next = MergeList(L1->next, L2);
return L1;
}
else {
L2->next = MergeList(L1, L2->next);
return L2;
}
}
最后
以上就是儒雅冥王星为你收集整理的数据结构 合并链表合并链表的全部内容,希望文章能够帮你解决数据结构 合并链表合并链表所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复