本题要求你计算A−B。不过麻烦的是,A和B都是字符串 —— 即从字符串A中把字符串B所包含的字符全删掉,剩下的字符组成的就是字符串A−B。
输入格式:
输入在2行中先后给出字符串A和B。两字符串的长度都不超过104,并且保证每个字符串都是由可见的ASCII码和空白字符组成,最后以换行符结束。
输出格式:
在一行中打印出A−B的结果字符串。
输入样例:
I love GPLT! It’s a fun game!
aeiou
输出样例:
I lv GPLT! It’s fn gm!
#include<iostream>
#include<cstring>
using namespace std;
int main()
{
char a[10001],b[10001],c[10001];bool p;
memset(c,0,sizeof(c));
scanf("\n%[^\n]s",a);scanf("\n%[^\n]s",b);
int index=0;
int lena=strlen(a),lenb=strlen(b);
for(int i=0;i<lena;i++)
{
p=1;
for(int j=0;j<=lenb;j++)
if(a[i]==b[j])
p=0;
if(p)
{
c[index++]=a[i];
}
}
for(int i=0;i<index;i++)
cout<<c[i];
return 0;
}
类似的题目有:
L1-2-字符串 6翻了 (15分)
“666”是一种网络用语,大概是表示某人很厉害、我们很佩服的意思。最近又衍生出另一个数字“9”,意思是“6翻了”,实在太厉害的意思。如果你以为这就是厉害的最高境界,那就错啦 —— 目前的最高境界是数字“27”,因为这是 3 个 “9”!
本题就请你编写程序,将那些过时的、只会用一连串“6666……6”表达仰慕的句子,翻译成最新的高级表达。
输入格式:
输入在一行中给出一句话,即一个非空字符串,由不超过 1000 个英文字母、数字和空格组成,以回车结束。
输出格式:
从左到右扫描输入的句子:如果句子中有超过 3 个连续的 6,则将这串连续的 6 替换成 9;但如果有超过 9 个连续的 6,则将这串连续的 6 替换成 27。其他内容不受影响,原样输出。
输入样例:
it is so 666 really 6666 what else can I say 6666666666
输出样例:
it is so 666 really 9 what else can I say 27
#include<iostream>
#include<cstring>
using namespace std;
int main()
{
char a[1010], b[1010];
scanf("%[^\n]s",a);
int i = 0, x = 0, index = 0;
while (a[i] != '\0')
{
if (a[i] != '6')
b[index++] = a[i];
else
{
x++;
if (a[i + 1] != '6')
{
if (x <= 3)
{
while (x--)
{
b[index++] = '6';
}
x = 0;
}
else if (x > 3 && x <= 9)
{
b[index++] = '9';
x = 0;
}
else if (x > 9)
{
b[index++] = '2';
b[index++] = '7';
x = 0;
}
}
}
i++;
}
for (int j = 0; j < index; j++)
putchar(b[j]);
return 0;
}