归并有序循环链表

思路:另外新建一个独立的链表作为合并的结果。设置两个指针,分布从两个表头开始,依次向后移动,并不断比较他们所指的元素的大小关系,每次把比较小的结点复制到新的循环链表中。

时间复杂度:每个结点访问一次,时间代价为O(n)。其中,n为链表list1和list2长度的最大值。

程序代码:

  LinkList combine_clink(LinkList list1,LinkList list2)

  {

    LinkList list3 = (LinkList)malloc(sizeof(struct Node));

    PNode p1 = list1->link,p2 = list2->link,p3 = list3;

    if(p1 == list1 && p2 == list2)    //如果list1和list2都是空表,则让空表头结点的指针指向头结点自己

    {

      list3->link = list3;

      return list3;

    }

    while(p1 != list1 || p2 != list2)

    {

      p3->link = (PNode)malloc(sizeof(struct Node));

      p3 = p3->link;

      if(p2 == list2 || (p1 != list1 && p1->info <= p2->info))

      //如果list2已搜索完毕,或者list1的当前元素不大于链表list2的当前元素

      {

        p3->info = p1->info;

        p1 = p1->link;

      }

      else

      //如果list1已搜索完毕,或者链表list1的当前元素大于链表list2的当前元素

      {

        p3->info = p2->info;

        p2 = p2->link;

      }

    }

    p3->link = list3;

    return list3;

  }

转载于:https://www.cnblogs.com/maomaohhmm/archive/2012/09/09/2677915.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值