世界那么大229 2022-10-08 17:11 采纳率: 66.7%
浏览 24
已结题

提问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-08 23: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月16日
  • 已采纳回答 10月9日
  • 创建了问题 10月8日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部