假设有两个按元素值递增次序排列的线性表,均以单链表形式储存。请编写算法将这两个单链表归并为一个按元素值递增次序排列的单链表,并要求利用原来两个单链表的结点存放归并后的单链表的结点
时间: 2023-04-10 10:05:14 浏览: 113
数据结构与算法 c++实现 两个单链表合并为一个单链表,两个表的元素交错排列,新表用原表结点的内存空间 按元素序列的奇偶分割单
5星 · 资源好评率100%
好的,让我来回答你的问题。这是一个经典的归并排序问题,我们可以使用双指针法来解决。具体步骤如下:
1. 定义一个新的链表,作为归并后的结果链表。
2. 定义两个指针,分别指向两个单链表的头结点。
3. 比较两个指针所指向的结点的值,将较小的结点插入到结果链表的末尾,并将指针后移一位。
4. 重复步骤3,直到其中一个链表为空。
5. 将另一个链表的剩余结点插入到结果链表的末尾。
6. 返回结果链表。
代码实现如下:
```
ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
ListNode* dummy = new ListNode(0);
ListNode* cur = dummy;
while (l1 && l2) {
if (l1->val < l2->val) {
cur->next = l1;
l1 = l1->next;
} else {
cur->next = l2;
l2 = l2->next;
}
cur = cur->next;
}
cur->next = l1 ? l1 : l2;
return dummy->next;
}
```
这个算法的时间复杂度是 O(n),其中 n 是两个单链表的总长度。
阅读全文