C++实现合并两个排序的链表

 更新时间:2019年03月03日 14:40:21   作者:francis_xd  
这篇文章主要为大家详细介绍了C++实现合并两个排序的链表,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C++合并两个排序的链表,供大家参考,具体内容如下

问题描述

输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。

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

方法一

class Solution {
public:
 ListNode* Merge(ListNode* pHead1, ListNode* pHead2)
 {
  ListNode* newList = NULL; //新链表头
  ListNode* newListRear = NULL; //新链表尾
  // 先处理某个链表为空的情形
  if (pHead1 == NULL){
   return pHead2;
  }
  if (pHead2 == NULL){
   return pHead1;
  }
  // 把数值小的结点放入新链表,生成头节点
  if (pHead1->val <= pHead2->val){
   newList = pHead1;
   newListRear = pHead1;
   pHead1 = pHead1->next;
  }else{
   newList = pHead2 ;
   newListRear = pHead2;
   pHead2 = pHead2->next;
  }
  // 两表均不空的情形下,遍历 
  while (pHead1 != NULL && pHead2 != NULL) {
   if (pHead1->val <= pHead2->val) {
    newListRear->next =pHead1;
    newListRear = pHead1;
    pHead1 = pHead1->next;
   }else{
    newListRear->next =pHead2;
    newListRear = pHead2;
    pHead2 = pHead2->next;
   }
  }
  //某一表为空时,把另一表接入新表表尾 
  if (pHead1 == NULL) {
   newListRear->next = pHead2;
  }
  if (pHead2 == NULL) {
   newListRear->next = pHead1;
  }
  
  return newList;
 }
};

方法二(递归思想)

class Solution {
public:
 ListNode* Merge(ListNode* pHead1, ListNode* pHead2)
 {
  if (pHead1 == NULL){
   return pHead2;
  }
  if (pHead2 == NULL){
   return pHead1;
  }
  
  if (pHead1->val <= pHead2->val){ // pHead1为合并后的头节点
   pHead1->next = Merge(pHead1->next, pHead2);
   return pHead1;
  }else{ // pHead2 为合并后的头节点
   pHead2->next = Merge(pHead1, pHead2->next);
   return pHead2;
  }
 }
};

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 探讨C++中不能声明为虚函数的有哪些函数

    探讨C++中不能声明为虚函数的有哪些函数

    下面小编就为大家带来一篇探讨C++中不能声明为虚函数的有哪些函数。希望对大家有所帮助。一起跟随小编过来看看吧,祝大家游戏愉快哦
    2017-01-01
  • Linux C/C++实现DNS客户端请求域名IP的示例代码

    Linux C/C++实现DNS客户端请求域名IP的示例代码

    DNS全称:Domain Name System,域名解析系统,是互联网的一项服务,本文主要介绍了C/C++如何实现DNS客户端请求域名IP,感兴趣的可以了解下
    2024-03-03
  • C++中STL容器的主要使用及含义说明

    C++中STL容器的主要使用及含义说明

    这篇文章主要介绍了C++中STL容器的主要使用及含义说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++中抽象类和接口的区别介绍

    C++中抽象类和接口的区别介绍

    抽象类(abstract class)和接口(interface)的概念是面向对象设计中常用的概念, 也是比较容易混淆的概念. 在这里, 我提出一种区分它们的思路
    2013-04-04
  • C++中按引用传递参数的好处有哪些

    C++中按引用传递参数的好处有哪些

    这篇文章主要介绍了C++中按引用传递参数的好处有哪些,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • C++ 超详细讲解stack与queue的使用

    C++ 超详细讲解stack与queue的使用

    C++ Stack(堆栈) 是一个容器类的改编,为程序员提供了堆栈的全部功能,也就是说实现了一个先进后出(FILO)的数据结构,许多程序都使用了 queue 容器。queue 容器可以用来表示超市的结账队列或服务器上等待执行的数据库事务队列
    2022-03-03
  • EasyC++ 右值引用

    EasyC++ 右值引用

    这篇文章主要介绍了C++ 右值引用,右值引用指的是以引用传递(而非值传递)的方式使用 C++ 右值,下面文章将对此详细介绍,需要的朋友可以参考一下,希望对你有所帮助
    2021-12-12
  • C++与QML进行数据交互的常见方法总结

    C++与QML进行数据交互的常见方法总结

    这篇文章主要为大家详细介绍了C++与QML进行数据交互的常见方法,文中 的示例代码讲解详细,具有一定的参考价值,有需要的小伙伴可以跟随小编一起了解一下
    2023-10-10
  • C++嵌入式内存管理详情

    C++嵌入式内存管理详情

    这篇文章主要介绍了C++嵌入式内存管理,是对上一篇内存的一个补充,主要讲解Linux中的内存;这部分对于一些端侧部署的伙伴来说比较重要,推荐针对不同的板子,下面来看看详细内容吧,需要的朋友可以参考一下
    2021-12-12
  • C++实现STL容器的示例

    C++实现STL容器的示例

    本文主要介绍了C++实现STL容器的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-02-02

最新评论