错误示范1:可能有的地方没想到
其实这个代码我偷懒了,如题说,短字符,所以只判断第一个和最后一个
基本思路
1、我先将两个字符串进行备份
2、将短字符串全变成小写,长字符串也变成小写(备份)
3、找到相应位置的时候同时对备份之前的长字符串进行修改变为’空格
4、输出不是空格的字符,
#include<cstdio>
#include<cstring>
/*
1、先都统一,都用备份
2、找第一个字母往后排len个位置
3、确定后标记
*/
void toLow(char *str);
void p(char *str);
char ans[10];
char ansT[10];
char str[20];
char strT[20];
int main(){
gets(ans);
strcpy(ansT, ans);
toLow(ansT);
while(gets(str) != NULL){
strcpy(strT, str);
toLow(strT);
int lenAns = strlen(ans);
int lenStr = strlen(str);
for(int i = 0; i < lenStr-lenAns+1; i++){
if(strT[i] == ansT[0] && strT[i+lenAns-1] == ansT[lenAns-1]){
for(int j = 0; j < lenAns; j++){
str[i+j] = ' ';
}
}
}
p(str);
}
return 0;
}
void toLow(char *str){
for(int i = 0; i < strlen(str); i++){
if(str[i] >= 65 && str[i] <= 90){
str[i] += 32;
}
}
}
void p(char *str){
int lenStr = strlen(str);
for(int i = 0; i < lenStr; i++){
if(str[i] != ' '){
printf("%c", str[i]);
}
}
printf("\n");
}
错误示范2:思路错
#include<cstdio>
#include<cstring>
void unnormal(char *li);
int main(){
char li[10];
char str[100];
scanf("%s", li);
unnormal(li);
getchar();
while(gets(str) != NULL){
int lenLi = strlen(li);
int lenStr = strlen(str);
for(int i = 0; i < lenStr; i++){
for(int j = 0; j < lenLi*2; j++){
if(str[i] == li[j]){
str[i] = ' ';
}
}
}
for(int i = 0; i < lenStr; i++){
if(str[i] != ' '){
printf("%c", str[i]);
}
}
printf("\n");
}
return 0;
}
void unnormal(char *li){
int lenLi = strlen(li);
for(int i = 0; i < lenLi; i++){
if(li[i] >= 'a'){
li[i+lenLi] = li[i] - 32;
}else{
li[i+lenLi] = li[i] + 32;
}
}
}