两个链表求交集

思路:釆用归并的思想,设置两个工作指针pa和pb,对两个链表进行归并扫描,只有同时出现在两集合中的元素才链接到结果表中且仅保留一个,其他的结点全部释放。当一个链表遍历完毕后,释放另一个表中剩下的全部结点。

LinkList Union(LinkList &la,LinkList &lb) {
    pa=la->next;  //设工作指针分别为pa和pb
    pb=lb->next;
    pc=la;  //结果表中当前合并结点的前驱指针
    while(pa&&pb){
        if(pa->data==pb->data) {  //交集并入结果表中
            pc->next=pa;    //A中结点链接到结果表
            pc=pa;
            pa=pa->next;
            u=pb;  //B中结点释放
            pb=pb->next;
            free(u);
        }
        else if (pa->data<pb->data) { //若A中当前结点值小于B中当前结点值
            u=pa;
            pa=pa->next;  //后移指针
            free(u) ; //释放A中当前结点
        }else{  //若B中当前结点值小于A中当前结点值
            u=pb;
            pb=pb->next;  //后移指针
            free (u) ;  //释放B中当前结点
        }
    }  //while 结束
    while(pa){    //B已遍历完,A未完
        u=pa;
        pa=pa->next;
        free (u) ;  //释放A中剩余结点
    }
    while(pb){  //A已遍历完,B未完
        u=pb;
        pb=pb->next;
        free(u) ; //释放B中剩余结点
    }
    pc->next=NULL;    //置结果链表尾指针为NULL
    free (lb) ;    //释放B表的头结点
    return la;
}

 

  • 9
    点赞
  • 56
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值