c实现set集合

2023-05-16

集合有点编程语言会带有,有的没有。但是我想redis的集合set你一定听说过或者用过。下面咱们用链表来实现set

相信有了前面的基础我们可以很容易的实现set集合

需要引入我的链表的list.c和list.h

头文件

//
//  set.h
//  set
//
//  Created by bikang on 16/9/18.
//  Copyright (c) 2016年 bikang. All rights reserved.
//

#ifndef __set__set__
#define __set__set__

#include <stdlib.h>
#include "list.h"

typedef List Set;

void set_init(Set *set,int(*match)(const void *k1,const void *k2),void(*destroy)(void*data));
#define set_destroy list_destroy
//插入
int set_insert(Set *set,const void *data);
//删除
int set_remove(Set *set,void **data);
//并集
int set_union(Set *setu,const Set *set1,const Set *set2);
//交集
int set_intersection(Set *seti,const Set *set1,const Set *set2);
//差集
int set_difference(Set *setd,const Set *set1,const Set *set2);
//是否是他的成员
int set_is_member(const Set *set,const void *data);
//是否是子集
int set_is_subset(const Set *set1,const Set *set2);
//是否相等
int set_is_equal(const Set *set1,const Set *set2);

#define set_size(set) ((set)->size)
#endif /* defined(__set__set__) */

实现

//
//  set.c
//  set
//
//  Created by bikang on 16/9/18.
//  Copyright (c) 2016年 bikang. All rights reserved.
//
#include <stdlib.h>
#include <string.h>

#include "set.h"


//初始化集合
void set_init(Set *set,int(*match)(const void *k1,const void *k2),void(*destroy)(void*data)){
    list_init(set,destroy);
    set->match = match;
    return;
}

//插入数据
int set_insert(Set *set,const void *data){
    if(set_is_member(set, data)){
        return 1;
    }
    return list_ins_next(set, list_tail(set), data);
}

//删除数据
int set_remove(Set *set,void **data){

    ListElmt *item,*pre;
    pre = NULL;
    for(item = list_head(set);item != NULL;item = list_next(item)){
        if(set->match(*data,list_data(item))) break;
        pre = item;
    }
    if(item == NULL) return -1;
    return list_rem_next(set, pre, data);
}
//并集
int set_union(Set *setu,const Set *set1,const Set *set2){
    ListElmt *item;
    void *data;
    set_init(setu, set1->match, NULL);
    for(item = list_head(set1);item != NULL;item = list_next(item)){
        data = list_data(item);
        if(list_ins_next(setu, list_tail(setu), data) != 0){
            set_destroy(setu);
            return -1;
        }
    }

    for(item = list_head(set2);item != NULL;item = list_next(item)){
        data = list_data(item);
        if(!set_is_member(setu, list_data(item))){
            if(list_ins_next(setu, list_tail(setu), data) != 0){
                set_destroy(setu);
                return -1;
            }
        }
    }
    return 0;
}

//交集
int set_intersection(Set *seti,const Set *set1,const Set *set2){
    ListElmt *item;
    void *data;
    set_init(seti, set1->match, NULL);

    for(item = list_head(set1);item != NULL;item = list_next(item)){
        if(set_is_member(set2, list_data(item))){
            data = list_data(item);
            if(list_ins_next(seti, list_tail(seti), data) != 0){
                set_destroy(seti);
                return -1;
            }
        }
    }
    return 0;
}

//差集
int set_difference(Set *setd,const Set *set1,const Set *set2){
    ListElmt *item;
    void *data;
    set_init(setd, set1->match, NULL);

    for(item = list_head(set1);item != NULL;item = list_next(item)){
        if(!set_is_member(set2, list_data(item))){
            data = list_data(item);
            if(list_ins_next(setd, list_tail(setd), data) != 0){
                set_destroy(setd);
                return -1;
            }
        }
    }
    return 0;
}


//是否是他的成员
int set_is_member(const Set *set,const void *data){
    ListElmt *item;
    for(item = list_head(set);item != NULL;item = list_next(item)){
        if(set->match(data,list_data(item))) return 1;
    }
    return 0;
}

//set1是否是set2的子集
int set_is_subset(const Set *set1,const Set *set2){
    ListElmt *item;
    // set1
    if(set_size(set1) > set_size(set2)) return 0;
    for(item = list_head(set1);item != NULL;item = list_next(item)){
        if(!set_is_member(set2, list_data(item))) return 0;
    }
    return 1;
}

//是否相等
int set_is_equal(const Set *set1,const Set *set2){
    if(set_size(set1) != set_size(set2)) return 0;

    return set_is_subset(set1, set2);
    return 0;
}




测试用例

//
//  main.c
//  set
//
//  Created by bikang on 16/9/18.
//  Copyright (c) 2016年 bikang. All rights reserved.
//

#include <stdio.h>
#include "set.h"

int match_data(const void *d1 ,const void *d2);


void t_match();
void tset();//测试set
void print_set(Set *set);//打印set

int main(int argc, const char * argv[]) {
    //t_match();
    tset();
    return 0;
}
void tset(){
    //初始化set1
    Set *set1 = (Set*)malloc(sizeof(Set));
    set_init(set1, match_data, NULL);
    //插入
    int i = 1; int *pi = &i;
    int i2 = 2;int *pi2 = &i2;
    int i3 = 3; int *pi3 = &i3;
    int i4 = 4;int *pi4 = &i4;
    int i5 = 5; int *pi5 = &i5;
    int i6 = 6;int *pi6 = &i6;
    int i7 = 2;int *pi7 = &i7;
    set_insert(set1, pi);
    set_insert(set1, pi2);
    set_insert(set1, pi3);
    set_insert(set1, pi4);
    set_insert(set1, pi5);
    set_insert(set1, pi6);
    set_insert(set1, pi7);
    print_set(set1);
    //集合大小
    printf("set_size=%d\n",set_size(set1));
    //删除
    set_remove(set1, (void**)&pi5);
    print_set(set1);
    //初始化set2
    Set *set2 = (Set*)malloc(sizeof(Set));
    set_init(set2, match_data, NULL);
    int i8 = 6; int *pi8 = &i8;
    int i9 = 7;int *pi9 = &i9;
    int i10 = 8;int *pi10 = &i10;
    set_insert(set2, pi8);
    set_insert(set2, pi9);
    set_insert(set2, pi10);
    print_set(set2);
    //并集
    Set *setu = (Set*)malloc(sizeof(Set));
    set_init(setu, match_data, NULL);
    set_union(setu, set1, set2);
     print_set(setu);
    //交集
    Set *seti = (Set*)malloc(sizeof(Set));
    set_init(seti, match_data, NULL);
    set_intersection(seti, set1, set2);
    print_set(seti);
    //差集
    Set *setd = (Set*)malloc(sizeof(Set));
    set_init(setd, match_data, NULL);
    set_difference(setd, set1, set2);
    print_set(setd);
    //是否是子集
    printf("set_is_sub=%d\n",set_is_subset(setd, set1));

    //摧毁集合
    set_destroy(set1);
    set_destroy(set2);

}
int match_data(const void *d1 ,const void *d2){
    if(*(int*)d1 == *(int*)d2) return 1;
    return 0;
}
void t_match(){
    int i = 1; int *pi = &i;
    int i2 = 2;int *pi2 = &i2;
    printf("match_result:%d",match_data(pi, pi2));
}

void print_set(Set *set){
    ListElmt *item;
    if(set_size(set) == 0) {
        puts("set is empty\n");
        return;
    }

    for(item = list_head(set);item != NULL;item = list_next(item)){
        printf("%d,",*(int*)list_data(item));
    }
    printf("\n");
    return;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

c实现set集合 的相关文章

  • C++:C 字符串集

    我想创建一个 以便我可以使用 set find 检查某个单词是否在集合中 然而 C 字符串是指针 因此默认情况下该集合将通过指针值来比较它们 为了正确运行 必须取消引用它们并比较字符串 我可以只向构造函数传递一个指向 strcmp 函数的指
  • 如何连接 MySQL 中的结果集?

    我想用逗号作为分隔符字符串来连接 MySQL 中集合中返回的结果 例如 返回的集合包含 COLUMN X john jerry maria joseph gugla 我希望收到的结果为 COLUMN X concat john jerry
  • .NET C# 中的设置操作

    我现在正在研究与粗糙集相关的东西 该项目使用了大量的集合操作和操作 我一直使用字符串操作作为集合操作的权宜之计 它一直工作得很好 直到我们需要通过算法处理一些大量的数据 500 000 条记录 每条记录大约 40 多列 我知道 net 2
  • 如何将两组 weka 实例合并在一起

    目前 我一次将一个实例从一个数据集复制到另一个数据集 有没有办法做到这一点 使字符串映射保持完整 mergeInstances 水平工作 是否有等效的垂直合并 这是我用来将多个 arff 文件中相同结构的数据集读取到一个大型数据集中的循环的
  • Python 字典中数组的交集

    我有数组字典 如下所示 y dict 1 np array 5 124 169 111 122 184 2 np array 1 2 3 4 5 6 111 184 3 np array 169 5 111 152 4 np array 0
  • 如何使用 set 维护列表的顺序?

    In 1 l1 a 2 3 0 9 0 0 2 6 b a In 2 l2 list set l1 In 3 l2 Out 3 a 0 2 3 6 9 0 b 在这里您可以看到列表 l2 的顺序与原始 l1 的顺序不同 我需要从列表中删除重
  • 如何在单个 SELECT 查询中设置多个 T-SQL 变量?

    我有3个变量 testid sampleid and clientid 我该如何设置 sampleid and clientid通过执行此查询一次 SELECT sample sampleid client clientid FROM db
  • Delphi XE2:如何使用序数值 > 255 的整数集

    我想做的就是定义一组值可能高于 255 的整数 但我没有看到任何好的选择 例如 with MyObject do Visible Tag in 100 155 200 225 240 Works just fine but with MyO
  • Python-从另一个列表中删除一组列表

    array1 1 2 3 4 5 6 7 8 9 array2 1 2 2 2 5 6 6 6 9 temp set array2 array1 remove temp Traceback most recent call last Fil
  • 如何在C#中获得一组枚举值?

    假设我有一个枚举 http msdn microsoft com en us library system windows forms dialogresult aspx namespace System Windows Forms pub
  • 是否有可嵌入的 Java 替代 Redis?

    根据这个线程 https stackoverflow com questions 3047010 best redis library for java 如果我想从Java中使用Redis Jedis是最好的选择 然而 我想知道是否有任何库
  • 如何在 C++ 中前向声明 std::set?

    为了加快编译过程 我正在尝试简化我的头文件MyClass hpp通过前向声明 STL 容器 例如 std vector std set But std set can NOT在以下代码中进行前向声明 同时std vector can be
  • 集合的“toArray”是确定性的吗?

    显然 集合没有任何类型的排序 所以如果我这样做的话 我不能期望任何特定的排序 String string mySet toArray 然而 我面临着一个用例 我不关心字符串数组的顺序 但我确实需要这样的情况 如果两个集合彼此相等 那么 St
  • 计算具有特定子集大小的集合分区

    给定一组n元素 我需要找到该集合的所有分区k大小几乎相等的子集 例如 对于一个包含 7 个元素和 3 个子集的集合 我只需要其中有两个子集 每个子集包含 2 个元素 和一个子集包含 3 个元素的分区 我不想要一个包含 1 2 和 4 个元素
  • 在java中迭代集合时从集合中删除项目

    我希望能够在迭代集合时从集合中删除多个元素 最初 我希望迭代器足够聪明 能够让下面的简单解决方案发挥作用 Set
  • 将一组 Java 对象转换为另一组对象的最佳方式是什么?

    这是一个真正的新手提出的基本 Java 问题 我有一组实现某个接口 接口 MyIfc 的Java对象 属于 MyClass 类 我有一组这些对象存储在我的类中的私有变量中 声明如下 protected Set
  • 如何在Linux中为特定程序设置进程ID

    我想知道是否有某种方法可以在运行某些应用程序之前强制使用 Linux 的某些特定进程 ID 我需要提前知道进程ID 实际上 有一种方法可以做到这一点 自内核 3 3 设置了 CONFIG CHECKPOINT RESTORE 在大多数发行版
  • 在 python 中对自定义类执行集合操作

    我想将 Python 的内置 set 类与我创建的自定义类一起使用 如果我愿意 要创建包含自定义类实例的集合 我需要实现哪些函数才能执行测试 例如 set a set b 它可以开箱即用 但是 在某些情况下 过载是有意义的 eq https
  • Ruby 中的 Set 是否始终保留插入顺序?

    即 Ruby 的 Set 相当于 Java 的 LinkedHashSet 吗 在 Ruby 1 9 中 yes 在 Ruby 1 8 中 可能不会 Set uses a Hash内部 https github com ruby ruby
  • 如何正确删除动画集中引用的 Raphael SVG 元素?

    我有一组动画 Raphael SVG 元素 我正在通过用户发起的 ajax 调用添加新元素并删除旧元素 我 set push 新元素 但因为我需要删除的元素通常不是集合中的最后一个元素 所以我使用 element remove 而不是 se

随机推荐

  • 【Java多线程】CompletableFuture的使用示例

    刘备 关羽和张飞三兄弟在家吧喝酒 xff0c 突然发现忘带钱了 xff0c 于是差下人回去取钱 为了不影响三兄弟喝酒的气氛 xff0c 刘备吩咐下人钱取来后交给旁边侍候的赵云即可 span class token keyword publi
  • 【Java基础】Arrays.sort()使用示例

    狗有名字 体重和年龄3个属性 xff1a span class token keyword public span span class token keyword class span span class token class nam
  • 【Spring】aop的使用示例

    场景 去饭店吃饭的时候 xff0c 在进入饭店时门卫会为你开门 xff0c 并问候说 欢迎光临 xff0c 当你吃完离开时 xff0c 门卫会说 请慢走 xff0c 欢迎下次光临 此场景下涉及如下两个角色 xff1a 顾客 xff08 cu
  • 关于从Github上下载历史版本

    第一步 打开一个仓库 xff0c 可以看到此时在主分支下 xff0c 点击1位置查看历史版本 第二步 现在可以查看到所有的版本 xff08 提交 xff09 信息 xff0c 单击2位置进入该版本 第三步 单击3位置浏览并打开该版本 第四步
  • 数据结构——结构体

    结构体是一种复合数据类型 xff0c 定义了一组变量列表 xff0c 这些变量将放在一个内存块中的名称下 它允许通过使用指向结构的一个指针来访问不同的变量 struct structure name data type member1 da
  • python 归并排序

    归并排序 xff08 Merge Sort xff09 是一种典型的递归法排序 它把复杂的 排序过程分解成一个简单的合并子序列的过程 至于怎么得到这个子 序列 xff0c 就得自己调用自己了 归并排序首先要做的就是将数列分成左右两部分 xf
  • ROS学习笔记—— rospy

    所有资料均来自于 https www icourse163 org learn ISCAS 1002580008 learn announce 和 https github com DroidAITech ROS Academy for B
  • XCOM(串口监视器,无单片机)+ESP8266显示心知天气天气信息

    XCOM xff08 串口监视器 xff0c 无单片机 xff09 43 ESP8266显示心知天气天气信息 ESP8266 AT指令显示 这是第一次写博客 xff0c 写的内容尽量通俗易懂贴近生活 PS 写的不好务必不要打我 ESP826
  • Linux编程——交叉编译器基本指令介绍

    Linux编程 交叉编译器基本指令介绍 arm span class token operator span linux span class token operator span gnueabihf span class token o
  • 马尔可夫链蒙特卡洛采样(MCMC)

    首先我们要明确的是马尔可夫链蒙特卡洛采样以下简称MCMC xff0c 它首先是个采样方法 1 采样的目的 采样作为任务 xff0c 用于生成新的样本求和 求积分 比如我们知道样本z的后验分布 我们经常会有一个需求 xff0c 得到目标函数f
  • dlang语法的简单整理

    dlang整理 为什么使用dlang 优点 xff1a 快速 xff0c 开发高效的 xff0c 方便 xff0c 无虚拟机的 xff0c 快速的 xff0c 高性能的 垃圾回收 缺点 xff1a 语法较为复杂 xff0c 支持gc 曾经很
  • docker 搭建基于prometheus的监控体系

    Prometheus是一个时间序列数据库 但是 xff0c 它不仅仅是一个时间序列数据库 它涵盖了可以绑定的整个生态系统工具集及其功能 Prometheus主要用于对基础设施的监控 包括服务器 xff0c 数据库 xff0c VPS xff
  • React回退上个页面及跳转下个页面

    回退上个页面 React 不保存数据 span class token keyword this span span class token punctuation span props span class token punctuati
  • Linux上jar包运行,但是接口测试Connect超时

    工作过程中遇到的 xff0c 这个异常就是连接超时 引起连接超时的问题有很多 xff0c 因为是feign调用超时 xff0c 我第一时间没怀疑是不是我的程序无法访问 xff0c 我一直怀疑是feigin那部分出错了 xff0c 什么跨服务
  • 网络调试助手(pc端)+ESP8266指令

    一 所需软件 链接 xff1a https pan baidu com s 1ycyOSZJOsiIocY3umrG7 g 提取码 xff1a 38f2 链接 xff1a https pan baidu com s 1EUuXUKcvf A
  • AD、PADS、allegro 哪个好用?

    AD PADS allegro 哪个好用 xff1f 用哪个都没问题 xff0c 都能完成任务 xff0c 主要看公司的选择了 AD是元老级的软件了 xff0c 也是PCB设计最先出的软件 xff0c 使用最为广范 在很多操作上都非常的人性
  • 基于python+pyqt5的串口助手

    基于python 43 pyqt5的串口助手 环境 xff1a pycharm python3 8 xff0c pyqt5 xff0c pyserial xff08 需要该节的工程文件 请私信 xff0c 或加VX xff1a Crazzy
  • STM32F4四轴飞行器总结

    xff08 菜鸡一枚 xff0c 记录一些学习的体会 xff0c 并记录了学习时提出的问题 xff0c 便于自己再次查阅 xff0c 若有错误之处 xff0c 希望大佬们指正 xff0c 谢谢 xff09 四旋翼简介 xff1a 嵌入式芯片
  • 详解RTK,RTD,SBAS,WAAS,PPP,PPK,广域差分等技术之间的关系与区别

    RTK与RTD的区别 xff0c 一个是载波相位差分 一个是码差分 xff0c 并且RTK的定位精度要高一些 RTK与PPK的区别 xff0c 一个是实时提供数据信息 xff0c 一个是事后处理 WAAS是SBAS系统一个具体的实例 xff
  • c实现set集合

    集合有点编程语言会带有 xff0c 有的没有 但是我想redis的集合set你一定听说过或者用过 下面咱们用链表来实现set 相信有了前面的基础我们可以很容易的实现set集合 需要引入我的链表的list c和list h 头文件 span