​ ​

练习7-4 找出不是两个数组共有的元素

前言

这个题目思路不是很复杂,主要是在于编写过程。
注意for循环的使用和flag标志。

正文

题目

给定两个整型数组,本题要求找出不是两者共有的元素。

输入格式:

输入分别在两行中给出两个整型数组,每行先给出正整数N(≤20),随后是N个整数,其间以空格分隔。

输出格式:

在一行中按照数字给出的顺序输出不是两数组共有的元素,数字间以空格分隔,但行末不得有多余的空格。题目保证至少存在一个这样的数字。同一数字不重复输出。

输入样例:

10 3 -5 2 8 0 3 5 -15 9 100 11 6 4 8 2 6 -5 9 0 100 8 1

输出样例:

3 5 -15 6 4 1

代码(正确)

#include <stdio.h>
int main()
{
    int N1,N2;//N1,N2为输入的两个数组的长度
    int GN1[20],GN2[20];//创建两个数组
    int p=0,num=0,flag=0;
    int GN3[20];//创建数组储存不同的数
    scanf("%d",&N1);
    int i,j;
 
    for(i=0; i<N1; i++)
    {
        scanf("%d",&GN1[i]);
    }
 
    scanf("%d",&N2);
    for(i=0; i<N2; i++)
    {
        scanf("%d",&GN2[i]);
    }
 /*用来储存数组GN1与数组GN2不同的元素存在数组GN3中*/
    for(i=0; i<N1; i++)
    {
        for(j=0; j<N2; j++)//用flag标记相同的元素
        {
            if(GN1[i]==GN2[j])
            {
                flag=1;
                break;
            }
        }
        for(p=0; p<num; p++)//除去GN3中相同的元素
        {
            if(GN3[p]==GN1[i])
            {
                flag=1;
                break;
            }
        }
        if(flag==0)GN3[num++] = GN1[i];
        flag = 0;
    }
 //保存数组GN2与数组GN1不同的元素存在数组GN3中
    for(j=0; j<N2; j++)
    {
        for(i=0; i<N1; i++)
        {
            if(GN2[j]==GN1[i])
            {
                flag=1;
                break;
            }
        }
        for(p=0; p<num; p++)
        {
            if(GN3[p]==GN2[j])
            {
                flag=1;
                break;
            }
        }
        if(flag==0) GN3[num++] = GN2[j];
        flag = 0;
    }
    printf("%d",GN3[0]);//输出第一个,保证最后一个元素后无空格
    for(i=1; i<num; i++)
    {
        printf(" %d",GN3[i]);
    }
    return 0;
}

代码参考https://blog.csdn.net/qq_41384798/article/details/101981385

posted @ 2020-03-12 14:39  Adeleeeeee  阅读(549)  评论(0)    收藏  举报