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;
}
A=AUB的更多相关文章
- 求新的集合 A=AUB(顺序表)
#include<stdio.h> typedef int A; const int LIST_INIT_SIZE=100; const int LISTINCREMENT=10; typ ...
- 分享一个html+js+ashx+easyui+ado.net权限管理系统
EasyUI.权限管理 这是个都快被搞烂了的组合,但是easyui的确好用,权限管理在项目中的确实用.一直以来博客园里也不少朋友分享过,但是感觉好的要不没源码,要不就是过度设计写的太复杂看不懂,也懒得 ...
- Oracle学习笔记九 数据库对象
Oracle 数据库对象又称模式对象,数据库对象是逻辑结构的集合,最基本的数据库对象是表. 其他数据库对象包括:
- shell脚本批量收集linux服务器的硬件信息快速实现
安装ansible批量管理系统.(没有的话,ssh远程命令循环也可以) 在常用的数据库里面新建一张表,用你要收集的信息作为列名,提供可以用shell插入.
- logback logback.xml常用配置详解 <filter>
<filter>: 过滤器,执行一个过滤器会有返回个枚举值,即DENY,NEUTRAL,ACCEPT其中之一.返回DENY,日志将立即被抛弃不再经过其他过滤器:返回NEUTRAL,有序列表 ...
- 深入解析SQL Server并行执行原理及实践(上)
在成熟领先的企业级数据库系统中,并行查询可以说是一大利器,在某些场景下他可以显著的提升查询的相应时间,提升用户体验.如SQL Server, Oracle等, Mysql目前还未实现,而Postgre ...
- C++基础——模拟事务 (1)COMMAND模式
=================================版权声明================================= 版权声明:原创文章 禁止转载 请通过右侧公告中的“联系邮 ...
- logback配置详解3<filter>
logback 常用配置详解(三) <filter> <filter>: 过滤器,执行一个过滤器会有返回个枚举值,即DENY,NEUTRAL,ACCEPT其中之一.返回DENY ...
- 【转】logback logback.xml常用配置详解(三) <filter>
原创文章,转载请指明出处:http://aub.iteye.com/blog/1110008, 尊重他人即尊重自己 详细整理了logback常用配置, 不是官网手册的翻译版,而是使用总结,旨在更快更透 ...
随机推荐
- Symantec Backup Exec 2012 Agent for Linux 卸载
本文介绍一下如何卸载Symantec Backup Exec 2012 Agent for Linx.首先我们来看看Symantec_Backup_Exec2012管理员手册的文档介绍: 卸载 Age ...
- 带你一步步的了解“C#事件”机制
是什么 本文讨论类型中定义的最后一种成员:事件 定义了时间成员的类型允许类型通知其他对象发生了特定的事情. 具体的说,定义了时间成员的类型能提供以下功能: 方法能登记它对事件的关注 方法能注销它对事件 ...
- Linux笔记:使用Vim编辑器
Vi编辑器是Unix系统上早先的编辑器,在GNU项目将Vi编辑器移植到开源世界时,他们决定对其作一些改进. 于它不再是以前Unix中的那个原始的Vi编辑器了,开发人员也就将它重命名为Vi improv ...
- Hadoop 之 MapReduce 框架演变详解
经典版的MapReduce 所谓的经典版本的MapReduce框架,也是Hadoop第一版成熟的商用框架,简单易用是它的特点,来看一幅图架构图: 上面的这幅图我们暂且可以称谓Hadoop的V1.0版本 ...
- linux mint17.2 安装fcitx输入法
mint17刚出的时候,曾经在虚拟机上体验过. 现在决定好好学习linux,再加上实在是太萌mint,就在虚拟机上安装了mint17.2 开始配置fcitx输入法: 添加ppa: sudo add-a ...
- 【小白的CFD之旅】13 敲门实例【续3】
接上文[小白的CFD之旅]12 敲门实例[续2] 4 Results4.1 计算监测图形4.2 Graphics4.2.1 壁面温度分布4.2.2 创建截面4.2.3 显示截面物理量4.2.4 Pat ...
- FTP协议
1. FTP协议 什么是FTP呢?FTP 是 TCP/IP 协议组中的协议之一,是英文File Transfer Protocol的缩写. 该协议是Internet文件传送的基础,它由一系列规格说明文 ...
- AutoCAD2006的安装及CASS7.1的配置破解
-----本文只限于学习交流,商业用途请支持正版! -----转载请注明:http://www.cnblogs.com/mxbs/p/6193190.html 准备: AutoCAD2006.CASS ...
- [No000079]罗辑思维2016.1.2日前的所有每日语音,python3做的网络爬虫
源码地址:https://github.com/charygao/Download_the_LouJiSiWei 写过很久了,vision1.0里有不少bug,今天重新整理修改了一下,运行了一下,2个 ...
- jQuery中的width() innerWidth() outerWidth() outerWidth(true)的区别
width()仅仅包括content(内容) innerWidth()包括content(内容)和padding(补白) outerWidth()包括content(内容),padding(补白)和b ...