将两个有序链表合并
题目:已知两个链表head1 和head2 各自有序,请把它们合并成一个链表依然有序。(保留所有结点,即便大小相同)。
递归实现:
1.函数返回条件是有一个链表结束,则返回另一个链表
2.取两个指针data域较小的作为新的头结点,递归调用
循环实现:
1.重新申请一个头结点,使用指针p指向他,每新加一个结点,就将指针p后移一位,即指针p永远指向新链表的尾结点
2.由于所用链表第一个结点不赋值,因此指针需要开始从头结点的下一个结点开始判断,如果两个指针都为非空,将data域较小的指针连在新链表的末尾
3.当两个指针有一个到达链表的结尾时,将没有到达末尾的链表连接到新链表之后。
#include<iostream>
using namespace std;
struct listnode
{
int data;
listnode *next;
};
//尾插法创建链表
listnode *init()
{
listnode *head=new listnode;
head->next=NULL;
listnode *p=head;
cout<<"please input a number(按-1结束)"<<endl;
int data;
cin>>data;
while(data!=-1)
{
listnode *temp=(listnode *)malloc(sizeof(listnode));
temp->data=data;
temp->next=p->next;
p->next=temp;
p=temp;
cout<<"please input a number(按-1结束)"<<endl;
cin>>data;
}
return head;
}
//打印链表
void print(listnode *head)
{
listnode *p=head->next;
while(p)
{
cout<<p->data<<" ";
p=p->next;
}
cout<<endl;
}
//将两个有序链表合并(循环实现)
listnode *hebing(listnode *head1,listnode *head2)
{
listnode *head=new listnode;
head->next=NULL;
//声明两个指针分别指向两个链表的数据开始部分
listnode *p1=head1->next;
listnode *p2=head2->next;
//声明一个指针来指向新链表的最后一个结点,开始时指向head
listnode *last=head;
while(p1!=NULL && p2!=NULL)
{
//p1结点的数据小:将last指向p1结点,last和p1分别后移
if(p1->data<p2->data)
{
last->next=p1;
p1=p1->next;
last=last->next;
}
//p2结点数据小:将last指向p2结点,last和p2分别后移
else
{
last->next=p2;
p2=p2->next;
last=last->next;
}
}
//当有一个链表结束时候,将last指向还未结束的链表
if(p1==NULL)
last->next=p2;
else if(p2==NULL)
last->next=p1;
return head;
}
//将两个有序链表合并(递归实现)
listnode *hebing2(listnode *head1,listnode *head2)
{
//循环结束条件:当一个链表到达结尾
if(head1==NULL)
return head2;
if(head2==NULL)
return head1;
listnode *head=NULL;
//选择两个头结点中较小的作为头结点
if(head1->data>head2->data)
{
head=head2;
head->next=hebing2(head1,head2->next);
}
else
{
head=head1;
head->next=hebing2(head1->next,head2);
}
return head;
}
//因为输出时候第一个结点时空的,需要填加一个空的头结点
listnode *diguihebing(listnode *head1,listnode *head2)
{
listnode *head=new listnode;
head->next=hebing2(head1->next,head2->next);
return head;
}
本文详细介绍了两种将两个有序链表合并成一个有序链表的方法:递归实现和循环实现。通过具体代码示例,展示了如何创建链表、打印链表,以及如何使用递归或循环方式将两个链表合并。
544

被折叠的 条评论
为什么被折叠?



