找出不是两个数组共有的元素

希望能在这个方法基础上修改😭🥺
题目

img

代码

img

错误

img


#include 
#include 
int main()
{
    int i,n1,n2;
    int a[20];
    int b[20];
    int c[20]={0},d[20]={0}; 
    scanf("%d",&n1);
    for(i=0;i<=n1;i++){        
        scanf("%d",&a[i]);
        c[i]++;
    }scanf("%d",&n2);
    for(i=0;i<=n2;i++){        
        scanf("%d",&b[i]);
        d[i]++;
    }for(i=0;i<20;i++){
        if(c[i]>0&&d[i]==0){
            printf("%d ",a[i]);
        }
    }for(i=0;i<20;i++){
        if(c[i]==0&&d[i]>0){
            printf("%d ",a[i]);
        }
    }
    return 0;
}

你要比较的是a和b呀,一直折腾c和d是要干啥
你的c和d里一开始全是0,执行完循环之后,循环里一直都是c[i]++,所以最终c里存的全是1
可以说数组c完全没有任何意义,存的东西没有价值

供参考:

#include <stdio.h>
int main()
{
    int i, j, n1, n2, k;
    int a[21];
    int b[21];
    int c[21] = { 0 };
    
    scanf("%d", &n1);
    for (i = 0; i < n1; i++) 
        scanf("%d", &a[i]);
    
    scanf("%d", &n2);
    for (i = 0; i < n2; i++) 
        scanf("%d", &b[i]);
    
    for (i = 0, k = 0; i < n1; i++) { //找出非共有元素
        for (j = 0; j < n2; j++) {
            if (a[i] == b[j]) 
                break;
        }
        if (j == n2) c[k++] = a[i];
    }
    for (i = 0; i < n2; i++) {
        for (j = 0; j < n1; j++) {
            if (b[i] == a[j]) 
                break;
        }
        if (j == n1) c[k++] = b[i];
    }

    for (i = 0, j = 0; i < k - j; i++) { //数组c[]去重
        for (n1 = i + 1; n1 < k - j; n1++)
            if (c[n1] == c[i])
            {
                for (n2 = n1; n2 < k - j; n2++)
                    c[n2] = c[n2 + 1];
                j++;
            }
    }
    for (i = 0; i < k - j; i++) //输出
        printf("%d ", c[i]);
    return 0;
}