首页 > 其他 > 详细

链表求差

时间:2016-05-22 21:28:28      阅读:143      评论:0      收藏:0      [点我收藏+]

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

//已知集合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;
        }
    }
}

 

链表求差

原文:http://www.cnblogs.com/ranjiewen/p/5517730.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!