链表求差

Posted 小河沟大河沟

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了链表求差相关的知识,希望对你有一定的参考价值。

链表指针参数和逻辑的分析。

//已知集合A和B的元素分别用不含头结点的单链表存储,函数difference()用于求解集合A与B的差集,并将结果保存在集合A的单链表中。
//例如,若集合A = { 5, 10, 20, 15, 25, 30 },集合B = { 5, 15, 35, 25 },完成计算后A = { 10, 20, 30 }。

#include<stdio.h>
#include<stdlib.h>
struct node
{
    int elem;
    node* next;
};

void difference(node** LA, node* LB)
{
    node *pa, *pb, *pre, *q;
    pre = nullptr;
    pa = *LA; //1   
    while (pa)  
    {
        pb = LB;
        while (pb&&pb->elem!=pa->elem)   //2   
            pb = pb->next;
        if (pb)    //不为空,说明有相同的,为空即没有相同的             
        {
            if (!pre)  //为空
                *LA = pa->next;     //4   
            else
                *LA = pre->next;     //5
            q = pa;
            pa = pa->next;
            free(q);
        }
        else  
        {
            pre=pa;             //6   
            pa = pa->next;
        }
    }
}

 

以上是关于链表求差的主要内容,如果未能解决你的问题,请参考以下文章

用C语言求线性表交集

单链表求表长

什么叫带头结点的链表? 什么叫不带头结点的链表?

Dijkstra+邻接表求次短路POJ Sightseeing 3463

求单链表的长度

hiho #1305 区间求差