Chinaunix首页 | 论坛 | 博客
  • 博客访问: 440670
  • 博文数量: 113
  • 博客积分: 446
  • 博客等级: 下士
  • 技术积分: 1229
  • 用 户 组: 普通用户
  • 注册时间: 2012-12-09 16:01
个人简介

Let's go!!!!!

文章分类

全部博文(113)

文章存档

2019年(5)

2018年(4)

2017年(9)

2016年(5)

2015年(39)

2014年(6)

2013年(28)

2012年(17)

分类: LINUX

2015-03-08 22:23:57

#include
#include
#include

#define True 1
#define False 0
#define error do{printf("Init set error!");exit(1);}while(0);

typedef int ElemType;
typedef int Status;

typedef struct NODE{
   ElemType data;
   struct NODE *next;
}Node;

typedef struct LINKSET{
   Node *head;
   int len;
}Linkset;

Status initset(Linkset *set)
{
   set->head = (Node *)malloc(sizeof(Node));
   if(!set->head)
       return False;
   set->head->next = NULL;
   set->len = 0;
   return True;
}

Status set_is_member(const Linkset *set,ElemType data)
{
   Node *list = set->head->next;
   while(list)
   {
       if(list->data == data)
           return False;
       list = list->next;
   }
   return True;
}

Status data_insert(Linkset *set,ElemType data)
{
   Node *list = set->head;
   Node *node = (Node *)malloc(sizeof(Node));
   if(!node)
       return False;
   node->data = data;
   node->next = list->next;
   list->next = node;
   set->len += 1;
   return True;
}

int set_insert(Linkset *set,ElemType data)
{
   if(!set_is_member(set,data))
   {
       return False;
   }
   return data_insert(set,data);
}

int set_remove(Linkset *set,ElemType data)
{
   Node *list1 = set->head->next;
   Node *list2 = set->head;
   while(list1)
   {
       if(list1->data == data)
       {
           list2->next = list1->next;
           set->len -= 1;
           free(list1);
           break;
       }
       else
       {
           list1 = list1->next;
           list2 = list2->next;
       }
   }
}

void show_set(Linkset *set)
{
   Node *list = set->head->next;
   while(list)
   {
       printf("%d \n",list->data);
       list = list->next;
   }
   printf("number:%d\n",set->len);
}

Linkset *union_set(Linkset *set1,Linkset *set2)
{
   Node *list1 = set1->head->next;
   Node *list2 = set2->head->next;
   Linkset *setu = (Linkset *)malloc(sizeof(Linkset));        
   if(!setu)
       error;
   initset(setu);
   while(list1)
   {
       set_insert(setu,list1->data);
       list1 = list1->next;
   }
   while(list2)
   {
       set_insert(setu,list2->data);
       list2 = list2->next;
   }
   return setu;
}

Linkset *intersection_set(Linkset *set1,Linkset *set2)
{
   Node *list1 = set1->head->next;
   Node *list2 = set2->head->next;
   Linkset *setn = (Linkset *)malloc(sizeof(Linkset));        
   if(!setn)
       error;
   initset(setn);
   while(list1)
   {
       if(!set_is_member(set2,list1->data))
       {
           set_insert(setn,list1->data);
       }
       list1 = list1->next;
   }
   return setn;
}

Linkset *different_set(Linkset *set1,Linkset *set2)
{
   Node *list1 = set1->head->next;
   Node *list2 = set2->head->next;
   Linkset *setd = (Linkset *)malloc(sizeof(Linkset));        
   if(!setd)
       error;
   initset(setd);
   while(list1)
   {
       if(!set_is_member(set2,list1->data))
       {
           set_insert(setd,list1->data);
       }
       list1 = list1->next;
   }
   return setd;
}

int main()
{
   ElemType i = 0;
   Linkset set1,set2,*setu,*setn,*setd;
   if(!initset(&set1) || !initset(&set2))
       error;
   for(i= 0;i < 10; i++)
       set_insert(&set1,i);
   for(i= 5;i < 15; i++)
       set_insert(&set2,i);
   set_remove(&set1,0);
   show_set(&set1);
   setu = union_set(&set1,&set2);         #set1 u set2
   show_set(setu);
   setn = intersection_set(&set1,&set2);  #set1 n set2
   show_set(setn);
   setd = different_set(&set1,&set2);     #set1 - set2
   show_set(setd);
}
阅读(1024) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~