A=AUB

#include<stdio.h>
#include<stdlib.h>

#define LIST_MAX 10
#define LIST_ADD 2

typedef struct
{
    int *elem;
    int length;
    int listsize;
}SqList;

int InitList(SqList *L)
{
    L->elem=(int *)malloc(LIST_MAX*sizeof(int));
    if(!L->elem)
        exit(-1);
    L->length=0;
    L->listsize=LIST_MAX;
    return 0;
}
int DestoryList(SqList *L)
{
    free(L->elem);
    L->elem=NULL;
    L->length=0;
    L->listsize=0;
    return 0;
}
int InsertElem(SqList *L,int i,int e)
{
    int *newbase,*p,*q;
    if(i<1||i>L->length+1)
        exit(-1);
    if(L->length>=L->listsize)
    {
        newbase=(int*)realloc(L->elem,(L->length+LIST_ADD)*sizeof(int));
        if(!newbase)
        {
            printf("分配空间失败!\n");
            exit(-1);
        }
        L->elem=newbase;
        L->listsize+=LIST_ADD;
    }
    p=L->elem+i-1;
    q=L->elem+L->length-1;
    for(;q>=p;q--)
        *(q+1)=*q;
    *p=e;
    ++L->length;
    return 0;
}    
int LocateElem(SqList L,int e,int (*visit)(int v1,int v2))
{
    int *p,i=1;
    p=L.elem;
    while(p<L.elem+L.length&&!visit(*p,e))
    {
        ++i;
        ++p;//需要考虑的是当在链表L中找不到满足条件的元素时,p会指向链表结尾的下一个元素的地址
    }
    if(i<=L.length)
        return i;
    else
        return 0;
}

int Equal(int v1,int v2)
{
    if(v1==v2)
        return 1;
    else
        return 0;
}                
int GetElem(SqList L,int i,int *e)
{
    if(i<1||i>L.length)
        exit(-1);
    *e=*(L.elem+i-1);
    return 1;
}
int Union(SqList *La,SqList Lb,int (*visit)(int v1,int v2))      //主要用到的合并函数
{
    int i=1;
    int e;
    for(;i<=Lb.length;i++)
    {
        GetElem(Lb,i,&e);
        if(!LocateElem(*La,e,visit))
        {
            InsertElem(La,La->length+1,e);
        }
    }
    return 0;
}
int main()
{
    int i,e0;
    SqList La,Lb;
    
    InitList(&La);

for(i=1;i<=6;i++)
        InsertElem(&La,i,i);

for(i=1;i<=6;i++)    
    {
        GetElem(La,i,&e0);
        printf("%d ",e0);
    }
    printf("\n");

InitList(&Lb);
    
    for(i=1;i<=6;i++)
        InsertElem(&Lb,i,2*i);

for(i=1;i<=6;i++)    
    {
        GetElem(Lb,i,&e0);
        printf("%d ",e0);
    }
    printf("\n");
    
    Union(&La,Lb,Equal);
    
    for(i=1;i<=La.length;i++)    
    {
        GetElem(La,i,&e0);
        printf("%d ",e0);
    }
    printf("\n");
    
    DestoryList(&La);
    DestoryList(&Lb);
    
    return 0;
}

时间: 2024-08-15 13:02:31

A=AUB的相关文章

推荐几个hadoop搭建的几个好的博文,亲测成功!

内容包括hadoop单机版.伪分布式.分布式搭建方式以及在Eclipse上面安装hadoop插件配置hadoop,本菜亲测成功,希望对大家能产生帮助: http://www.cnblogs.com/kinglau/category/509016.html http://www.cnblogs.com/huligong1234/p/3533382.html http://aub.iteye.com/category/302369

2-2-求并集A=A∪B-线性表-第2章-《数据结构》课本源码-严蔚敏吴伟民版

课本源码部分 第2章  线性表 - 求并集A=A∪B ——<数据结构>-严蔚敏.吴伟民版        源码使用说明  链接??? <数据结构-C语言版>(严蔚敏,吴伟民版)课本源码+习题集解析使用说明        课本源码合辑  链接??? <数据结构>课本源码合辑        习题集全解析  链接??? <数据结构题集>习题解析合辑        本源码引入的文件  链接? SequenceList.c        相关测试数据下载  链接? 无数

剑指架构师系列-spring boot的logback日志记录

Spring Boot集成了Logback日志系统. Logback的核心对象主要有3个:Logger.Appender.Layout 1.Logback Logger:日志的记录器 主要用于存放日志对象,也可以定义日志类型.级别. 级别:ERROR.WARE.INFO.DEBUG和TRACE.没有FATAL,归纳到了ERROR级别里.ERROR.WARN and INFO level messages are logged by default. 在Spring Boot中,最好定义为logb

logback logback.xml常用配置详解(三) &lt;filter&gt;

转自:logback logback.xml常用配置详解(三) <filter> logback 常用配置详解(三) <filter> <filter>: 过滤器,执行一个过滤器会有返回个枚举值,即DENY,NEUTRAL,ACCEPT其中之一.返回DENY,日志将立即被抛弃不再经过其他过滤器:返回NEUTRAL,有序列表里的下个过滤器过接着处理日志:返回ACCEPT,日志会被立即处理,不再经过剩余过滤器. 过滤器被添加到<Appender> 中,为<

logback logback.xml常用配置详解(二)&lt;appender&gt;

logback 常用配置详解(二) <appender> <appender>: <appender>是<configuration>的子节点,是负责写日志的组件. <appender>有两个必要属性name和class.name指定appender名称,class指定appender的全限定名. 1.ConsoleAppender: 把日志添加到控制台,有以下子节点: <encoder>:对日志进行格式化.(具体参数稍后讲解 ) &

logback logback.xml常用配置详解(一)&lt;configuration&gt; and &lt;logger&gt;

logback 配置详解(一)<configuration> and <logger> 一:根节点<configuration>包含的属性:scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true.scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒.当scan为true时,此属性生效.默认的时间间隔为1分钟.debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看l

排列组合-容斥原理

De Morgan定理   (1)   (2) (2)成立 (1)成立 (*) 证明(*): 由于n=2,即(2)式,成立 根据数学归纳法,假设(*)成立 即:,则有 证毕. 容斥原理,定义|A|为集合A的元素个数 预备知识:若则|AUB|=|A|+|B|   若则|AUB|最多被计算一次 因此:|AUB|=|A|+|B|-|| 进一步: 等价于: 可采用数学归纳法证明,类比(*)式的证明 又由于: 所以:      

logback简介

转载:http://aub.iteye.com/blog/1101222 logback 简介 Ceki Gülcü在Java日志领域世界知名.他创造了Log4J ,这个最早的Java日志框架即便在JRE内置日志功能的竞争下仍然非常流行.随后他又着手实现SLF4J 这个"简单的日志前端接口(Fa?ade)"来替代Jakarta Commons-Logging . LOGBack,一个"可靠.通用.快速而又灵活的Java日志框架". 要在工程里面使用logback需要

logback详细配置(三)

转自:http://blog.csdn.net/haidage/article/details/6794540 <filter>: 过滤器,执行一个过滤器会有返回个枚举值,即DENY,NEUTRAL,ACCEPT其中之一.返回DENY,日志将立即被抛弃不再经过其他过滤器:返回NEUTRAL,有序列表里的下个过滤器过接着处理日志:返回ACCEPT,日志会被立即处理,不再经过剩余过滤器. 过滤器被添加到<Appender> 中,为<Appender> 添加一个或多个过滤器后