链表问题_合并两个排序链表

本文介绍如何将两个递增排序的链表合并成一个新的递增排序链表,提供了递归和迭代两种实现方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:输入两个递增排序的链表,合并这两个排序链表,使得合并之后的链表仍然使递增排序的。
分析:即是归并排序中的归并操作,有两种具体的实现:1、使用递归的方法,2、迭代版本,逐个合并链表。实现如下:

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) :
            val(x), next(NULL) {
    }
};*/

/*递归版本*/
  ListNode*merge(ListNode*phead1, ListNode*phead2)
  {
      if (phead1 == NULL)
          return phead2;
      else if (phead2 == NULL)
          return phead1;

      ListNode*pmergehead = NULL;
      if (phead1->val < phead2->val)
      {
          pmergehead = phead1;
          pmergehead->next=merge(phead1->next, phead2);
      }
      else
      {
          pmergehead = phead2;
          pmergehead->next=merge(phead1, phead2->next);
      }
     return pmergehead ;
  }

/*迭代版本*/
ListNode*Merge(ListNode*phead1, ListNode*phead2)
  {
      if (phead1 == NULL)
          return phead2;
      else if (phead2 == NULL)
          return phead1;

      ListNode* pnode1 = phead1;
      ListNode* pnode2 = phead2;
      ListNode* pmergehead = NULL;

      if (phead1->val < phead2->val)
      {
          pnode1 = pnode1->next;
          pmergehead = phead1;
      }
      else
      {
          pnode1 = pnode1->next;
          pmergehead = phead1;
      }
      ListNode*pnode3 = pmergehead;
      while (pnode1&&pnode2)
      {
          if (pnode1->val < pnode2->val)
          {
              pnode3->next = pnode1;
              pnode3 = pnode3->next;
              pnode1 = pnode1->next;
          }
          else
          {
              pnode3->next = pnode2;
              pnode3 = pnode3->next;
              pnode2 = pnode2->next;
          }
      }

      while (pnode1)
      {
          pnode3->next = pnode1;
          pnode3 = pnode3->next;
          pnode1 = pnode1->next;
      }

      while (pnode2)
      {
          pnode3->next = pnode2;
          pnode3 = pnode3->next;
          pnode2 = pnode2->next;
      }
      return pmergehead;
  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值