7-8 找出不是两个数组共有的元素 (20分) 给定两个整型数组,本题要求找出不是两者共有的元素。 输入格式: 输入分别在两行中给出两个整型数组,每行先给出正整数N(≤20),随后是N个整数,其间以

#include

int main()
{
	int a,b,v=0,f,sum=0;
	scanf("%d",&a);
	int c[a];
	for(int i=0;i<a;i++){
		scanf("%d",&c[i]);
	}
	scanf("%d",&b);
	int d[b];
	for(int i=0;i<b;i++){
		scanf("%d",&d[i]);
	}
	int m[20];
	for(int i=0;i<a;i++){
		for(int j=0;j<b;j++){
			if(c[i]==d[j]){
			m[v]=c[i];
			v++;	
			}
		}
	}
	int h[20];
	for(int i=0;i<a;i++){
		for(int j=0;j<=v;j++){
			f=0;
			if(c[i]==m[j]){
				f=1;
				break;
			}
			}
			if(f==0){
				h[sum]=c[i];
				sum++;
			}
	}
		for(int i=0;i<b;i++){
		for(int j=0;j<=v;j++){
			f=0;
			if(d[i]==m[j]){
				f=1;
				break;
			}
			}
			if(f==0){
				h[sum]=d[i];
				sum++;
			}
}
			int o=0;
			for(int i=0;i<sum;i++){
				for(int j=i+1;j<sum;j++){
					if(h[i]==h[j]){
						o++;
					}
				}
			}
			for(int i=0;i<sum;i++){
				for(int j=i+1;j<sum;j++){
					if(h[i]==h[j]){
						h[j]=h[j+1];
					}
				}
			}
		
			for(int i=0;i<sum-o;i++){
				printf("%d",h[i]);
				if(i!=sum-o-1)printf(" ");
			}
}

你可能感兴趣的:(c)