考研算法题练习2022.11.12

这篇博客介绍了如何使用链式存储结构实现集合的交集和并集操作。func1函数通过双指针循环遍历实现交集,func2函数则先将两个集合合并到c中,再去除重复元素得到并集。这两个算法都是针对链表数据结构的基本操作,对于理解数据结构和算法设计有帮助。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 设有两个集合A和集合B,要求设计生成集合C=A∩B的算法,其中集合A、B和C用链式存储结构表示。(求并集)
//求交集  思想:双指针循环遍历 
void func1(LinkList a,LinkList b,LinkList &c){
	LNode *pc=c;		
	pc->next = NULL;
	for(LNode *pa=a->next;pa!=NULL;pa=pa->next){
		for(LNode *pb=b->next;pb!=NULL;pb=pb->next){
			if(pa->data==pb->data){
				LNode *s = new LNode;
				s->data = pa->data;
				s->next = pc->next;
				pc->next = s;
				pc = s;
			}
		}
	}
} 
//求并集  思想:将两个链表先全部存入c中,再将c中重复元素去除   
void func2(LinkList a,LinkList b,LinkList &c){  
    LNode *pc = c;  
    pc->next = NULL;  
    for(LNode *pa=a->next;pa!=NULL;pa=pa->next){  
        LNode *s = new LNode;  
        s->data = pa->data;  
        s->next = pc->next;  
        pc->next = s;  
        pc = s;  
    }  
    for(LNode *pb=b->next;pb!=NULL;pb=pb->next){  
        LNode *s = new LNode;  
        s->data = pb->data;  
        s->next = pc->next;  
        pc->next = s;  
        pc = s;   
    }//5 4 6 7 8 2 4 5 6 1  
    for(pc=c->next;pc->next!=NULL;pc=pc->next){  
        for(LNode *pd=pc->next,*pre=pc;pd!=NULL;pd=pd->next,pre=pre->next){  
            if(pc->data==pd->data){  
                LNode *s = pd;  
                pre->next = pd->next;  
                pd = pd->next;  
                free(s);  
            }  
        }  
    }  
}  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值