世界那么大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 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持