【100题】第四十一题 非降序链表的并集

一,题目

两个非降序链表的并集,1->2->3 和 2->3->5 并为 1->2->3->5。另外只能输出结果,不能修改两个链表的数据。

二,递归解法

#include <iostream>
using namespace std;

struct Node

{

    int data;

    Node * next;

};

 

Node * MergeRecursive(Node *head1 , Node *head2)

{

  if ( head1 == NULL )

    return head2 ;

  if ( head2 == NULL)

    return head1 ;

  Node *head = new Node() ;

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

  {

    head = head1 ;

    head->next = MergeRecursive(head1->next,head2);

  }

  else

  {

    head = head2 ;

    head->next = MergeRecursive(head1,head2->next);

  }

  return head ;

}

Node *creatLink(int a[],int n)

{

        Node *head=new Node();

        head->data=a[0];

        Node *tail=head;

        head->next=NULL;

        for(int i=1;i<n;++i)

        {

               Node *temp=new Node();

               temp->data=a[i];

               temp->next=NULL;

               

               tail->next=temp;

               tail=tail->next;

        }
        return head;     

}

int main()

{

        int a[]={1,2,4,6,7};

        int b[]={2,3,5,7,8};

        Node *headA=creatLink(a,5);

        Node *headB=creatLink(b,5);

        Node *headResult= MergeRecursive(headA , headB);

        

        while(headResult)

        {

               cout<<headResult->data<<" ";

               headResult=headResult->next;

        }

} 


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值