B3654 [语言月赛202208] 影子字符串 解析

题目描述

给出多个字符串(数目未知),每行一个。

其中有可能会有重复的字符串,而我们认为在这些字符串中,较靠后出现的都是靠前出现的字符串的"影子"。

例如,

复制代码
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

结论

这道题考察了以下几点:

第一:数组的定义;

第二:结束输入的判断;

第三:字符串的定义;

以上是《影子字符串》的解析

我是修勾,我们下期再见

相关推荐
王老师青少年编程23 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:魔法
c++·算法·贪心·csp·信奥赛·排序贪心·魔法
wearegogog12324 分钟前
基于和差波束法的单脉冲测角MATLAB实现
人工智能·算法·matlab
AI科技星32 分钟前
灵魂商数(SQ) · 全域数学统一定义【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
晓觉儿33 分钟前
【GPLT】2026年第十一届团队程序设计天梯赛赛后题解(已写2h,存档中)
数据结构·c++·算法·深度优先·图论
We་ct39 分钟前
LeetCode 322. 零钱兑换:动态规划入门实战
前端·算法·leetcode·typescript·动态规划
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 394. 字符串解码 | C++ 单栈回压法
c++·算法·leetcode
穿条秋裤到处跑2 小时前
每日一道leetcode(2026.04.22):距离字典两次编辑以内的单词
算法·leetcode
淘矿人2 小时前
Claude辅助算法设计与优化
人工智能·python·算法·microsoft·github·bug·pygame
流年如夢2 小时前
自定义类型进阶:联合与枚举
java·c语言·开发语言·数据结构·数据库·c++·算法
wayz112 小时前
Day 10:集成学习进阶(Boosting: AdaBoost, GBDT)
算法·机器学习·集成学习·boosting