合并两个有序的单链表

25计算机考研,数据结构知识点整理(内容借鉴了王道408+数据结构教材),还会不断完善所整理的内容,后续的内容也会不断更新(可以关注),若有错误和不足欢迎各位朋友指出!

目录

1.算法思想

2.算法描述


删除算法中的循环条件(pre->nex!!=NULL&&k<i-1)与前插算法中的循环条件(pre!=NULL&&k<i-1)不同,因为前插时的插入位置有n+1个(n为当前单链表中数据元素的个数),i=n+1是指在第n+1个位置前插人,即在单链表的末尾插入,而删除操作中删除的合法位置只有几个,若使用与前插操作相同的循环条件,则会出现指针指空的情况,使删除操作失败。

1.算法思想

要利用现有的表LA和LB中的结点空间来建立新表LC,可通过更改结点的next域来重建新的元素之间的线性关系。为保证新表仍然递增有序,可采用尾插法建立单链表,只是新建表中的结点不用malloc,仅需从表LA和LB中选择合适的点插入新表LC即可。

2.算法描述

cpp 复制代码
LinkList MergeLinkList( LinkList LA,LinkList LB)
/*将递增有序的单链表LA和LB合并成一个递增有序的单链表LC*/
{
  Node *pa,*pb;
  LinkList LC;
  /*将LC初始置空表。pa和pb分别指向两个单链表LA和LB中的第一个结点,r初值为LC且始终指向LC的表尾*/
   pa=LA->next;
   pb=LB->next ;
   LC=LA;
   LC->next=NULL;r=LC;
   /*当两个表均未处理完时,比较选择将较小值结点插入新表LC*/
   while(pa!= NULL&&pb!=NULL)
   { if( pa->data<=pb->data)
      {r->next=pa;r=pa;pa=pa->next;}
     else
      {r->next=pb;r=pb;pb= pb->next;}
   }
   if(pa)/*若表LA未完,将表LA中后续元素链到新表LC表尾*/
      r->next= pa;
   else /*否则将表LB中后续元素链到新表LC表尾*/
        r->next= pb;
     free( LB);
     return(LC);
}  /* MergeLinkList * /
相关推荐
用户0099383143011 小时前
代码随想录算法训练营第十三天 | 二叉树part01
数据结构·算法
shinelord明1 小时前
【再谈设计模式】享元模式~对象共享的优化妙手
开发语言·数据结构·算法·设计模式·软件工程
薄荷故人_1 小时前
从零开始的C++之旅——红黑树及其实现
数据结构·c++
努力学习编程的伍大侠2 小时前
基础排序算法
数据结构·c++·算法
XiaoLeisj2 小时前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Jackey_Song_Odd3 小时前
C语言 单向链表反转问题
c语言·数据结构·算法·链表
乐之者v3 小时前
leetCode43.字符串相乘
java·数据结构·算法
A懿轩A4 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
️南城丶北离5 小时前
[数据结构]图——C++描述
数据结构··最小生成树·最短路径·aov网络·aoe网络
✿ ༺ ོIT技术༻5 小时前
C++11:新特性&右值引用&移动语义
linux·数据结构·c++