不使用额外空间,将 A,B两链表的元素交叉归并

思想:先将pHead1拿出,pcurA指向phead1的下一个结点,再声明一个
*pCurB;*pNextB;分别指向phead2的当前和下一个结点,每次连接,1不断,2断开。


typedef struct LinkNode{
int data;
LinkNode* pNext;
}LinkNode;



void mergeList(ListNode* headA, ListNode*headB)

{

    if(NULL ==headA)

         {

        return headB;

    }

 

         if(NULL ==headB)

         {

        return headA;

    }

 

        

    LinkNode*pRet;

    LinkNode*pCurA;

    LinkNode*pCurB;

    LinkNode*pNextB;

    LinkNode*preA;

 

    pCurA= headA->pNext;

    pCurB= pHeadB;

    pRet= pHeadA;

    preA= pRet;

    while(pCurA !=NULL && pCurB != NULL)

    {

        pNextB= pCurB->pNext;

        preA->pNext =pCurB;

        pCurB->pNext =pCurA;

        preA= pCurA;

        pCurB= pNextB;

        pCurA= pCurA->pNext;

    }

    if (pCurA ==NULL)

    {

        preA->pNext=pCurB;

    }

 

    return pRet;

}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值