《C链表实现集合的差运算》

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

#define DataType int
#define TRUE 1
#define FALSE -1

struct Node{
DataType data;
struct Node * next;
};

typedef
struct {
struct Node * node_Pointer;
int Size;
}
set , * set_Pointer;

int init_Set(set_Pointer s){
s
-> node_Pointer = NULL;
s
-> Size = 0 ;
return TRUE;
}

int insert_Item(set_Pointer * s, const DataType item){
struct Node * p = ( * s) -> node_Pointer;
while (p){
if (item == p -> data){
return FALSE;
}
p
= p -> next;
}
p
= ( * s) -> node_Pointer;
struct Node * q = ( struct Node * )malloc( sizeof (Node));
if ( ! q){
exit(
1 );
}
q
-> data = item;
q
-> next = p;
(
* s) -> node_Pointer = q;
++ ( * s) -> Size;
return TRUE;
}

int remove_Item(set_Pointer * s, const int item){
if (( * s) -> node_Pointer){
struct Node * p, * q;
p
= q = ( * s) -> node_Pointer;
if (item == p -> data){
(
* s) -> node_Pointer = p -> next;
-- ( * s) -> Size;
free(p);
return TRUE;
}
while (p){
p
= p -> next;
if (item == p -> data){
q
-> next = p -> next;
free(p);
-- ( * s) -> Size;
break ;
}
q
= q -> next;
}
return TRUE;
}
return FALSE;
}

int search_Item( const set_Pointer s, const DataType item){
if (s -> node_Pointer){
unsigned
int index = 1 ;
struct Node * p = s -> node_Pointer;
while (p){
if (item == p -> data){
return index;
}
++ index;
p
= p -> next;
}
}
return FALSE;
}

int difference_Set( const set_Pointer s1, const set_Pointer s2, set_Pointer * s){
if (s1 -> node_Pointer && s2 -> node_Pointer) {
struct Node * p = s1 -> node_Pointer;
DataType item;
while (p){
item
= p -> data;
if (search_Item(s2, item) <= 0 ){
insert_Item(s, item);
}
p
= p -> next;
}
return TRUE;
}
return FALSE;
}

int show_Item( const set_Pointer s){
if (s -> node_Pointer){
struct Node * p = s -> node_Pointer;
printf_s(
" Set Size : %d\n " , s -> Size);
while (p){
printf_s(
" %d\n " , p -> data);
p
= p -> next;
}
return TRUE;
}
return FALSE;
}

int main(){
return EXIT_SUCCESS;
}

转载于:https://www.cnblogs.com/intelligentfish/archive/2011/04/09/2010732.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值