A-B (20 分)
本题要求你计算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<stdio.h>
#include<string.h>
int main()
{
int i=0,j=0; //用于循环和数组下标
char str1[10010]; //用来存储A、B两个字符串
char str2[10010]; //用来存储要删除的字符串字母
int length; //用来存储字符串长度
gets(str1);
gets(str2);
length = strlen(str2); //这里只需要记住str2字符串的长度即可
while(str1[i]!='\0') //将str1字符串从第一个字母开始带进去一一查验
{
for(j=0;j<length;j++)//将这个字母放到str2中一一查询是否有对应的,若有对应的
{ //那么for循环就会提前跳出,并且j的值不可能会等于length,
if(str1[i]==str2[j])//记住关键词,提前!所以从这里就可以肯定若for循环执行
break; //到了最后,那么证明这个字母在str2中是找不到对应的,
} //那么自然需要显示啦!
if(j==length)
printf("%c",str1[i]);
i++;
}
printf("\n");
return 0;
}
利用bool
bool数组必须初始化(bool asc[128]={0};),否则会出现任意值
#include <stdio.h>
#include <stdbool.h>
#include <string.h>
int main(){
char a[10001],b[10001];
bool asc[128]={0}; //赋值全为false
gets(a);
gets(b);
int i,j;
for (i=0; b[i]!='\0'; i++){
asc[b[i]]=true; //字符以ASCII码储存
}
for (i=j=0; a[i]!='\0'; i++){
if (!asc[a[i]]) // 假如a[i]在 b数组没有出现
a[j++]=a[i];
}
a[j]='\0'; //在字符串a最后面加\0
puts(a);
return 0;
}
strchr()函数
#include<stdio.h>
#include<string.h>
int main()
{
char a[10001] = { 0 }, b[10001] = { 0 };
gets(a);
gets(b);
for (int i = 0;i < strlen(a);i++)
{
if (strchr(b, a[i]))
continue;
else
printf("%c", a[i]);
}
return 0;
}