两个有序链表合并

链表操作小结:

一个链表的结点结构

struct Node

{

int data ;

Node *next ;

};

typedef struct Node Node ;

(1)已知链表的头结点head,写一个函数把这个链表逆序 ( Intel)

Node * ReverseList(Node *head) //链表逆序

{

if ( head == NULL || head->next == NULL )

return head;

Node *p1 = head ;

Node *p2 = p1->next ;

Node *p3 = p2->next ;

p1->next = NULL ;

while ( p3 != NULL )

{

p2->next = p1 ;

p1 = p2 ;

p2 = p3 ;

p3 = p3->next ;

}

p2->next = p1 ;

head = p2 ;

return head ;

}


(2)已知两个链表head1 和head2 各自有序,请把它们合并成一个链表依然有序。(保留所有结点,即便大小相同)

Node * Merge(Node *head1 , Node *head2)

{

if ( head1 == NULL)

return head2 ;

if ( head2 == NULL)

return head1 ;

Node *head = NULL ;

Node *p1 = NULL;

Node *p2 = NULL;

if ( head1->data < head2->data )

{

head = head1 ;

p1 = head1->next;

p2 = head2 ;

}

else

{

head = head2 ;

p2 = head2->next ;

p1 = head1 ;

}

Node *pcurrent = head ;

while ( p1 != NULL && p2 != NULL)

{

if ( p1->data <= p2->data )

{

pcurrent->next = p1 ;

pcurrent = p1 ;

p1 = p1->next ;

}

else

{

pcurrent->next = p2 ;

pcurrent = p2 ;

p2 = p2->next ;

}

}

if ( p1 != NULL )

pcurrent->next = p1 ;

if ( p2 != NULL )

pcurrent->next = p2 ;

return head ;

}


(3)已知两个链表head1 和head2 各自有序,请把它们合并成一个链表依然有序,这次要求用递归方法进行。 (Autodesk)

答案:

#include<cstdio>
#include<iostream>
using namespace std;
struct Node{
    int data;
    Node *next;
};
Node *Merge(Node *head1,Node *head2)
{
    if(head1==NULL)
		return head2;
	if(head2==NULL)
		return head1;
	Node *head=NULL;
	if(head1->data<head2->data)
	{
		head=head1;
		head->next=Merge(head1->next,head2);
	}
	else
	{
		head=head2;
		head->next=Merge(head1,head2->next);
	}
	return head;
}
void print(Node *k)
{
	cout<<k->data<<" ";
	while(k->next!=NULL)
	{
		k=k->next;
		cout<<k->data<<" ";
	}
	cout<<endl;
}
int main()
{
	int i,n,m;
	Node *head1=NULL,*head2=NULL,*p,*q;
	cin>>n;
	p=new Node;q=new Node;
	for(i=0;i<n;i++)
	{
		if(i==0)
		{
			cin>>p->data;
			p->next=NULL;
			head1=p;
		}
		else
		{
			Node *h=new Node;
			cin>>h->data;
			h->next=NULL;
			p->next=h;
			p=p->next;
		}
	}

	cin>>m;
	for(i=0;i<m;i++)
	{
		if(i==0)
		{
			cin>>q->data;
			q->next=NULL;
			head2=q;
		}
		else
		{
			Node *w=new Node;
			cin>>w->data;
			w->next=NULL;
			q->next=w;
			q=q->next;
		}
	}

	print(head1);
	print(head2);

    Node *ptr;
    ptr=Merge(head1,head2);
    print(ptr);
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值