天任考研小编为大家整理了“2023考研计算机模拟试题(4)”相关内容,为报考计算机专业的考生们提供指导。更多有关计算机考研干货可关注考研备考栏目。
2023考研计算机模拟试题(4)
(2)将两个非递减的有序链表合并为一个非递增的有序链表。要求结果链表仍使用原来两个链表的存储空间, 不另外占用其它的存储空间。表中允许有重复的数据。
[题目分析]
合并后的新表使用头指针Lc指向,pa和pb分别是链表La和Lb的工作指针,初始化为相应链表的第一个结点,从第一个结点开始进行比较,当两个链表La和Lb均为到达表尾结点时,依次摘取其中较小者重新链接在Lc表的表头结点之后,如果两个表中的元素相等,只摘取La表中的元素,保留Lb表中的元素。当一个表到达表尾结点,为空时,将非空表的剩余元素依次摘取,链接在Lc表的表头结点之后。
[算法描述]
void MergeList(LinkList& La, LinkList& Lb, LinkList& Lc, )
{//合并链表La和Lb,合并后的新表使用头指针Lc指向
pa=La->next; pb=Lb->next;
//pa和pb分别是链表La和Lb的工作指针,初始化为相应链表的第一个结点
Lc=pc=La; //用La的头结点作为Lc的头结点
Lc->next=NULL;
while(pa||pb )
{//只要存在一个非空表,用q指向待摘取的元素
if(!pa) {q=pb; pb=pb->next;}
//La表为空,用q指向pb,pb指针后移
else if(!pb) {q=pa; pa=pa->next;}
//Lb表为空,用q指向pa,pa指针后移
else if(pa->data<=pb->data) {q=pa; pa=pa->next;}
//取较小者(包括相等)La中的元素,用q指向pa,pa指针后移
else {q=pb; pb=pb->next;}
//取较小者Lb中的元素,用q指向pb,pb指针后移
q->next = Lc->next; Lc->next = q;
//将q指向的结点插在Lc 表的表头结点之后
}
delete Lb; //释放Lb的头结点
}