题目描述
给出多个字符串(数目未知),每行一个。
其中有可能会有重复的字符串,而我们认为在这些字符串中,较靠后出现的都是靠前出现的字符串的"影子"。
例如,
abc
def
abc
abc
abc
我们在第 1,3,4,51,3,4,5 行都出现了字符串 abc
,那么 3,4,53,4,5 行的字符串会被称为"影子字符串"。
现在要求把所有的非影子字符串 都按照行号从小到大依次拼接为一个长串并输出。
输入格式
多个字符串,每行一个,含义见题目描述。
注意:输入结尾以字符串 0
结束(即一行里仅有一个 0
)。
输出格式
共一行,表示所有非影子字符串按照行号从小到大依次拼接成的一个长串。
题目解析
以上是题目描述,在这之中我们可以知道可以输入很多同样的字符,但是只能输出"所有非影子字符串按照行号从小到大依次拼接成的一个长串。"并且这是一条,没有分割
解答
cpp
#include<iostream>
#include<cstring>
using namespace std;
char a[505][50005];
int main()
{
char b[50005];
int i,cnt,f;
cnt=0;
while(1)
{
cin>>b;
if(b[0]=='0'&&b[1]=='\0')
{
break;
}
f==0;
for(i=0;i<=cnt;i++)
{
if(strcmp(a[i],b)==0)
{
f==1;
break;
}
}
if(f==0)
{
strcpy(a[++cnt],b);
}
}
for(i=0;i<=cnt;i++)
{
cout<<a[i];
}
return 0;
}
单独解答
变量作用
cpp
i,cnt,f
i的作用:
让for循环执行
cnt的作用:
表示二维数组字符当中存储了多少个只出现过一次的字符串
f的作用:
是否有只出现过一次的字符串:
其余作用
while(1)的作用:
重复寻找只出现过一次的字符串
第一个if的作用:
判断什么时候停止输入
第一个for的作用:
查找只出现过一次的字符串
strcmp单独的作用:
strcmp(A,B):比较A与B中的较小的值
第三个if的作用:
判断是不是没有只出现过一次的字符串
strcpy单独的作用:复制
在文中的作用:把b数组复制到a数组里
最后一个for的作用:
输出只出现过一次的字符串
运行的结果
输入:
cpp
cc
b
a
cc
0
输出:
cpp
ccba
结论
这道题考察了以下几点:
第一:数组的定义;
第二:结束输入的判断;
第三:字符串的定义;
以上是《影子字符串》的解析
我是修勾,我们下期再见