世界那么大229 2022-10-09 01:11 采纳率: 66.7%
浏览 22
已结题

提问C语言递归实现两个有序链表归并且无重复数字?

能够实现归并但不知道如何将重复数字合并或者说覆盖掉,删除
LinkList MergeList(LinkList pa,LinkList pb)
{//递归实现两个有序单链表的归并
LinkList p = NULL;
if(NULL==pa)
{
return pb;
}
else if(NULL==pb)
{
return pb;
}
else
{
if(pa->data < pb->data)
{
p = pa;
p->next = MergeList(pa->next,pb);
}
else
{
p = pb;
p->next = MergeList(pa,pb->next);
}
return p;
}

}
而且会多一个首数字0

  • 写回答

1条回答 默认 最新

  • _GX_ 2022-10-09 07:22
    关注
    LinkList *MergeList(LinkList *pa, LinkList *pb) { //递归实现两个有序单链表的归并
      if (!pa)
        return pb;
    
      if (!pb)
        return pa;
    
      Node *p, *q;
      if (pa->data < pb->data) {
        p = pa;
        q = MergeList(pa->next, pb);
      } else {
        p = pb;
        q = MergeList(pa, pb->next);
      }
      while (q && q->data == p->data) // 去重
        q = q->next;
      p->next = q;
      return p;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月17日
  • 已采纳回答 10月9日
  • 创建了问题 10月9日

悬赏问题

  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd