A1021. 集合运算

A1021. 集合运算
时间限制: 1.0s   内存限制: 512.0MB  
问题描述
  给出两个整数集合A、B,求出他们的交集、并集以及B在A中的余集。
输入格式
  第一行为一个整数n,表示集合A中的元素个数。
  第二行有n个互不相同的用空格隔开的整数,表示集合A中的元素。
  第三行为一个整数m,表示集合B中的元素个数。
  第四行有m个互不相同的用空格隔开的整数,表示集合B中的元素。
  集合中的所有元素均为int范围内的整数,n、m<=1000。
输出格式
  第一行按从小到大的顺序输出A、B交集中的所有元素。
  第二行按从小到大的顺序输出A、B并集中的所有元素。
  第三行按从小到大的顺序输出B在A中的余集中的所有元素。
样例输入
5
1 2 3 4 5
5
2 4 6 8 10
样例输出
2 4
1 2 3 4 5 6 8 10
1 3 5
样例输入
4
1 2 3 4
3
5 6 7
样例输出
1 2 3 4 5 6 7
1 2 3 4

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <algorithm>
  4. #define MAX 2001
  5. using namespace std;
  6. bool cmp(int x, int y){
  7.     return x<y;
  8. }
  9. void jiao(int a[],int n,int b[],int m){
  10.     int i,j,k=0;
  11.     int c[MAX];
  12.     for(i=0;i<n;i++){
  13.         for(j=0;j<m;j++){
  14.             if(a[i]==b[j])
  15.                 c[k++]=a[i];
  16.         }
  17.     }
  18.     sort(c,c+k,cmp);
  19.     for(i=0;i<k;i++){
  20.         printf("%d ",c[i]);
  21.     }
  22.     printf("\n");
  23. }
  24. void bing(int a[],int n,int b[],int m){
  25.     int i,j,k=0,count=0;
  26.     int c[MAX];
  27.     for(i=0;i<n;i++)
  28.         c[i]=a[i];
  29.     
  30.     for(j=0;j<m;count=0,j++){
  31.         for(i=0;i<n;i++){
  32.             if(b[j]!=a[i]){
  33.                 if(count==n-1){
  34.                     c[n+k]=b[j];
  35.                     k++;
  36.                 }
  37.                 count++;
  38.             }
  39.         }
  40.     }
  41.     
  42.     sort(c,c+n+k,cmp);
  43.     for(i=0;i<n+k;i++){
  44.         printf("%d ",c[i]);
  45.     }
  46.     printf("\n");
  47. }
  48. void yu(int a[],int n,int b[],int m){
  49.     int i,j,k=0,count=0;
  50.     int c[MAX];
  51.     for(i=0;i<n;count=0,i++){
  52.         for(j=0;j<m;j++){
  53.             if(a[i]!=b[j]){
  54.                 if(count==m-1){
  55.                     c[k]=a[i];
  56.                     k++;
  57.                 }
  58.                 count++;
  59.             }
  60.         }
  61.     }
  62.     sort(c,c+k,cmp);
  63.     for(i=0;i<k;i++){
  64.         printf("%d ",c[i]);
  65.     }
  66.     printf("\n");
  67. }
  68. int main(){
  69.     int i,j,n,m;
  70.     int a[MAX],b[MAX];
  71.     scanf("%d",&n);
  72.     for(i=0;i<n;i++){
  73.         scanf("%d ",&a[i]);
  74.     }
  75.     scanf("%d",&m);
  76.     for(i=0;i<m;i++){
  77.         scanf("%d ",&b[i]);
  78.     }
  79.     jiao(a,n,b,m);
  80.     bing(a,n,b,m);
  81.     yu(a,n,b,m);
  82.     
  83.     system("pause");
  84.     return 0;
  85. }

注意MAX需要2000以上才行。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值