1. 数据结构 用c语言写的 集合的并、交和差运算的程序
可以用二个一维数组,
再用两个for循环来判断结果:交,并,差
在for循环中,用一个if来判断一下,是不是a[0]==b[j],只要有相等的,就令之放在c[0]
     这就是交集!!
    
并集就好求吧,
只要令c[i]=a[i],再来一个就是c[i+j+1]=b[j](因为我这里是考虑j=0开始的,然后自加差就是在交上改动一下就可以了,只要是a[0]!=b[j],就把它放到c[]这个数组里面去~!!!! 
1:并集的程序。
求集合LA和集合LB的并集
    #define NULL 0
    struct JD
    { int data;
      struct JD *next;
    };
    int find(int number,struct JD *h)
    { while(h->data)
       { if(h->data!=number)
           { h=h->next;
         continue;
           }
         else
           return 0;
       }
      return 1;
    }
    struct JD * make()
    { struct JD *h=NULL,*p=NULL;
      int number,tf;
      h=(struct JD *)malloc(sizeof(struct JD));
      scanf("%d",&h->data);
      p=h;
      while(p->data)
        { p->next=(struct JD *)malloc(sizeof(struct JD));
          p=p->next;
          p->data=0;
          scanf("%d",&number);
          tf=find(number,h);
          if(tf)
        p->data=number;
          else
        continue;
        }
      return h;
    }
    
    void print(struct JD *h)
    { while(h->data)
       { printf("%d ",h->data);
         h=h->next;
       }
    }
    
    struct JD * change(struct JD *la,struct JD *lb)
    { struct JD *h,*p,*s,*q;
      int number,tf;
      p=lb;
      while(p->data)
        { number=p->data;
          tf=find(number,la);
          p=p->next;
          if(tf)
        { s=(struct JD *)malloc(sizeof(struct JD));
          s->data=number;
          s->next=la;
          la=s;
        }
          else
        continue;
        }
      return la;
    }
    
    void del(struct JD *h)
    { struct JD *p=h->next;
      while(h->data)
       { free(h);
         h=p;
         p=p->next;
       }
      free(h);
    }
    main()
    { struct JD *la,*lb;
      printf("\n\nGive the number to LA :\n\n");
      la=make();
      printf("\nLA is:   ");
      print(la);
      printf("\n\nGive the number to LB :\n\n");
      lb=make();
      printf("\nLB is:   ");
      print(lb);
      la=change(la,lb);
      printf("\n\n\nThe new LA=LA||LB is:   ");
      print(la);
      del(la);
      del(lb);
      printf("\n\n\nPass any key to exit...!\n");
      getch();
    }
********** 程序运行结果 **********
        Give the number to LA :
        1↓
        2↓
        3↓
        5↓
        0↓
        LA is:   1 2 3 5
        Give the number to LB :
        6↓
        7↓
        3↓
        2↓
        9↓
        0↓
        LB is:   6 7 3 2 9
The new LA=LA||LB is:   9 7 6 1 2 3 5
--------------------------------------------------
        Pass any key to exit...!
2. 如何利用c语言实现集合的运算
这种集合问题,一般是使用链表来处理。
比如说有两个链表list1,list2,它们分别用来存储集合A,B
如果要对A,B进行并运算,
那么可以首先定义一个新的链表list3,然后让list1和list2的值进行循环的比较,如果有相同的值,那么就将这个值放入list3中,直到没有相同的值为止。
大致的算法就是这样了。
3. C语言求集合运算
可以用线性表模拟集合,把两个线性表中一样的数提取出来就是交集,所有元素组成的就是并集,还可以用C++重载运算符实现+就求并集之类的。
4. 用C语言编写一个集合的交,并和差运算的程序怎么写啊
/*第一,你的题意不明,我只能输入两个集合了【互异性由输入保证】*/
#include<stdio.h>
#include<string.h>
void main()
{
char temp[60]="",str1[30]="",str2[30]="",i,j,l1,l2,ch;
printf("STR1:");
gets(str1);
printf("STR2:");
gets(str2);
l1=strlen(str1);
l2=strlen(str2);
//交集
printf(" 交集: {");
for(i=0;i<l1;i++)
for(j=0;j<l2;j++)
if(str1[i]==str2[j]) printf("%c,",str1[i]);
printf("} ");
//并集 偷懒的算法: 合并->排序->删除相同
printf(" 并集: {");
/*合并*/sprintf(temp,"%s%s",str1,str2);
/*排序*/
for(i=0;i<l1+l2-1;i++)
for(j=i+1;j<l1+l2;j++)
if(temp[i]>temp[j])
{
char ch;
ch=temp[i];
temp[i]=temp[j];
temp[j]=ch;
}
/*删除相同字符*/
for(i=j=1;i<l1+l2;i++)
if(temp[i]!=temp[j-1]) temp[j++]=temp[i];
temp[j]='
