4 个解决方案
#1
仅供参考
#include <stdio.h>
#include <string.h>
#include <locale.h>
char s[256];
char *p;
int r,n,i;
int main() {
setlocale(LC_ALL,"chs");
while (1) {
printf("请输入一行文字(空行结束),\"%%20\"将替换为\" \",\"你懂得\"将替换为\"XXXXXX\":\n");
fgets(s,256,stdin);
if ('\n'==s[0]) break;
p=s;
while (1) {
p=strstr(p,"%20");
if (p) {
memmove(p+1,p+3,strlen(p)-3+1);
p[0]=' ';
} else break;
}
p=s;
while (1) {
p=strstr(p,"你懂得");
if (p) {
memmove(p+6,p+6,strlen(p)-6+1);
for (i=0;i<6;i++) p[i]='X';
} else break;
}
printf("%s",s);
}
return 0;
}
//请输入一行文字(空行结束),"%20"将替换为" ","你懂得"将替换为"XXXXXX":
//abcdefg%20helloworld%20something.pdf
//abcdefg helloworld something.pdf
//请输入一行文字(空行结束),"%20"将替换为" ","你懂得"将替换为"XXXXXX":
//这是测试文字你懂得,在这个你懂的地方,就得做你懂得的事
//这是测试文字XXXXX,在这个你懂的地方,就得做XXXXX的事
//请输入一行文字(空行结束),"%20"将替换为" ","你懂得"将替换为"XXXXXX":
//
#2
一个一个读,遇见就跳过去。
#3
//将串s1中的子串s2替换成串s3
char*replace(char*s1,char*s2,char*s3=NULL)
{
char *p,*from,*to,*begin=s1;
int c1,c2,c3,c; //串长度及计数
c2=strlen(s2);
c3=(s3!=NULL)?strlen(s3):0;
if(c2==0)return s1; //注意要退出
while(true) //替换所有出现的串
{
c1=strlen(begin);
p=strstr(begin,s2); //出现位置
if(p==NULL) //没找到
return s1;
if(c2>c3) //串往前移
{
from=p+c2;
to=p+c3;
c=c1-c2+begin-p+1;
while(c--)
*to++=*from++;
}
else if(c2<c3) //串往后移
{
from=begin+c1;
to=from-c2+c3;
c=from-p-c2+1;
while(c--)
*to--=*from--;
}
if(c3) //完成替换
{
from=s3,to=p,c=c3;
while(c--)
*to++=*from++;
}
begin=p+c3; //新的查找位置
}
}
#4
循环判断每个字符,如果是'\r' 或者 '\n',则替换掉。
#1
仅供参考
#include <stdio.h>
#include <string.h>
#include <locale.h>
char s[256];
char *p;
int r,n,i;
int main() {
setlocale(LC_ALL,"chs");
while (1) {
printf("请输入一行文字(空行结束),\"%%20\"将替换为\" \",\"你懂得\"将替换为\"XXXXXX\":\n");
fgets(s,256,stdin);
if ('\n'==s[0]) break;
p=s;
while (1) {
p=strstr(p,"%20");
if (p) {
memmove(p+1,p+3,strlen(p)-3+1);
p[0]=' ';
} else break;
}
p=s;
while (1) {
p=strstr(p,"你懂得");
if (p) {
memmove(p+6,p+6,strlen(p)-6+1);
for (i=0;i<6;i++) p[i]='X';
} else break;
}
printf("%s",s);
}
return 0;
}
//请输入一行文字(空行结束),"%20"将替换为" ","你懂得"将替换为"XXXXXX":
//abcdefg%20helloworld%20something.pdf
//abcdefg helloworld something.pdf
//请输入一行文字(空行结束),"%20"将替换为" ","你懂得"将替换为"XXXXXX":
//这是测试文字你懂得,在这个你懂的地方,就得做你懂得的事
//这是测试文字XXXXX,在这个你懂的地方,就得做XXXXX的事
//请输入一行文字(空行结束),"%20"将替换为" ","你懂得"将替换为"XXXXXX":
//
#2
一个一个读,遇见就跳过去。
#3
//将串s1中的子串s2替换成串s3
char*replace(char*s1,char*s2,char*s3=NULL)
{
char *p,*from,*to,*begin=s1;
int c1,c2,c3,c; //串长度及计数
c2=strlen(s2);
c3=(s3!=NULL)?strlen(s3):0;
if(c2==0)return s1; //注意要退出
while(true) //替换所有出现的串
{
c1=strlen(begin);
p=strstr(begin,s2); //出现位置
if(p==NULL) //没找到
return s1;
if(c2>c3) //串往前移
{
from=p+c2;
to=p+c3;
c=c1-c2+begin-p+1;
while(c--)
*to++=*from++;
}
else if(c2<c3) //串往后移
{
from=begin+c1;
to=from-c2+c3;
c=from-p-c2+1;
while(c--)
*to--=*from--;
}
if(c3) //完成替换
{
from=s3,to=p,c=c3;
while(c--)
*to++=*from++;
}
begin=p+c3; //新的查找位置
}
}
#4
循环判断每个字符,如果是'\r' 或者 '\n',则替换掉。