【数据结构】(单链表)求两个链表的交集

算法思想:其实就是合并链表相同的元素(假设链表有序)

 void Union(LinkList &A,LinkList &B){
 	
 	if(A->next==NULL||B->next==NULL)
 		return ;
 		
 	LinkList pa=A->next;
	LinkList pb=B->next;
	LinkList r=A;
	LinkList sa;
	LinkList sb;
	A->next=NULL;
	
	while(pa&&pb){
		if(pa->data==pb->data){
			sa=pa->next;
			sb=pb->next;
			pa->next=r->next;//尾插法
			r->next=pa;
			r=pa;
			pa=sa;
			free(pb);
			pb=sb;
		}else if(pa->data<pb->data){
			sa=pa->next;
			free(pa);
			pa=sa;
		}else{
			sb=pb->next;
			free(pb);
			pb=sb;
		}
	}
	
	while(pa){
		sa=pa->next;
		free(pa);
		pa=sa;
	}
	
	while(pb){
		sb=pb->next;
		free(pb);
		pb=sb;
	}
	
	free(B);
 	r->next=NULL;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值