当前位置:   article > 正文

两个有序链表在不占用其他的内存的情况下合并成一个新的链表(类似到归并排序的归并)_不占用额外空间合并链表

不占用额外空间合并链表
  1. int MergeList_L(Linklist &L1,Linklist &L2,Linklist &L3)
  2. {
  3. Linklist p=L3;
  4. while(L1->next&&L2->next)
  5. {
  6. if(L1->next->data<=L2->next->data)
  7. {
  8. p->next=L1->next;//拼接
  9. L1->next=L1->next->next;//将节点移走
  10. p=p->next;//游标右移始终保持在最后一个节点
  11. }
  12. else
  13. {
  14. p->next=L2->next;
  15. L2->next=L2->next->next;
  16. p=p->next;
  17. }
  18. }
  19. if(L1->next)
  20. p->next=L1->next;//剩余直接拼接
  21. if(L2->next)
  22. p->next=L2->next;//同上
  23. }

思想:

节点逐个拼接,移动;

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/算法设计者/article/detail/62941
推荐阅读
相关标签
  

闽ICP备14008679号