计蒜课难题题库之奇怪的国家

这是很简单的一道题啊:

有一个奇怪的国家,里面的国民对于事情的态度永远只有两面。当两个人遇到一起讨论一个事情的时候——两个持赞同观点的人遇到一起后会对这个事情都继续赞同;一个持赞同观点的人遇到一个持不赞同观点的人的时候,两人都会不再继续赞同;两个持不赞同观点的人遇到一起讨论后反而会对这个事情开始赞同。

输入包括两行,每行包括N个数字(1≤N≤50),分别表示两个人对于N个事情对应的看法——0表示不赞同、1表示赞同。

输出包括一行,包括N个数字,表示两人相遇后,对于这N件事情的最终看法。

输入:

1
2
11100101
00101011

输出:

1
00110001

我的思路很简单,没有做什么字符型数组与整数数组的转化,就是简单的比较两个字符数组每个元素的大小,相同第三个数组就为1,否则就为0。

代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void judge(char a1[],char a2[],char a3[],int long_num)
{
int i;
for(i=0;i<long_num;i++)
{
if(a1[i]==a2[i])
{
a3[i]='1';
}
else
{
a3[i]='0';
}
}
a3[long_num]='\0';

}
int main()
{
char a1[50];
char a2[50];
int long1,long_num;
int i;
gets(a1);
gets(a2);
long_num=strlen(a1);
if(long_num!=strlen(a2))
{
printf("Different lenth");
exit(0);
}
char *a3;
a3=malloc(sizeof(char)*(long_num+1));
judge(a1,a2,a3,long_num);
puts(a3);
}

总结:

我遇到了个问题,就是gets与fgets输入时,gets会舍弃最后的换行符,而fgets会加入数组,所以长度会比gets多一。