求 高手解决 C++ 字符串替换问题

定义一个结构体变量给字符串赋值然后把想要替换的多个字符替换为指定的单个字符比如输入abcdefgh把cde换成l于是最后输出ablllfgh... 定义一个结构体变量 给字符串赋值 然后把想要替换的多个字符替换为指定的单个字符 比如输入abcdefgh 把 cde换成l 于是最后输出 ablllfgh 展开
 我来答
jinsong1zhang
2009-06-30 · TA获得超过532个赞
知道小有建树答主
回答量:409
采纳率:0%
帮助的人:359万
展开全部
#include<iostream>
using namespace std;
struct Str
{
char datas[100];
char replace[100];
char data;
void get_datas()
{
cout<<"请输入一个字符串:"<<endl;
scanf("%s",datas);
}
void get_rep()
{
cout<<"请输入要被替换的字符(以串的形式输入):"<<endl;
scanf("%s",replace);
}
void get_data()
{
cout<<"请输入你想替换成的字符:"<<endl;
cin>>data;
}
void replacement()
{
int index=0;
int num=0;
int j;
while(replace[num]!='\0')
num++;
while(datas[index]!='\0')
{
for(j=0;j<num;j++)
{
if(datas[index]==replace[j])
break;
}
if(j<num)
datas[index]=data;
index++;
}
cout<<"替换后的字符串为:"<<endl;
printf("%s",datas);
}
};
int main()
{
Str obj;
obj.get_datas();
obj.get_rep();
obj.get_data();
obj.replacement();
}
lchn_kyd
2009-06-30 · TA获得超过299个赞
知道小有建树答主
回答量:559
采纳率:0%
帮助的人:297万
展开全部
就把字符串读进来,顺序检测,遇到要替换的字符就进行处理,然后输出就好了啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2009-06-30
展开全部
为什么要定义结构体变量给字符串赋值?难道是你的结构体里面定义了很多字符串成员?你的描述我还没太弄清楚。
给你推荐下面的字符串查找替换程序,我写的,还行,短小实用。已经推荐给几个人了。当然这只是一个小程序,功能单一。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 10000 /* 设定文件最大字符个数不超过10000,可更改 */

int main()
{
int i=0,j,k=0,m=0,pos=0,max,len1,len2;
char s[N],t[N],a[200],s1[200],s2[200];
FILE *fp;
printf("Please input file name:\n");/*输入文件名*/
gets(a);
printf("Please input original string:\n");/*输入要替换的字符串*/
gets(s1);
printf("Please input new string:\n");/*输入被替换成的字符串*/
gets(s2);
len1=strlen(s1);
len2=strlen(s2);
if ((fp=fopen(a,"r"))==NULL)/*设定文件位于当前目录下,可更改为绝对路径*/
{ printf("Open file %s error! Strike any key to exit!",a);
system("pause");
exit(1);
}
s[i++]=fgetc(fp);
while(!feof(fp))
{s[i++]=fgetc(fp);
}
fclose(fp);

max=i-1;/* 函数feof()最后会读两次,所以必须减1 */
for(i=0;i<max-len1;i++)
{for(j=0;j<len1&&(s[i+j]==s1[j]);j++);
if(j!=len1)
continue;/* 不相等则i加1进行下一次外循环 */
else
{ for(k=0;k<i-pos;k++)/* pos记录开始复制的位置 */
t[m++]=s[pos+k];
pos=i+len1;
for(k=0;k<len2;k++)/* 字符串替换 */
t[m++]=s2[k];
}
}
for(k=pos;k<max;k++)/* 复制剩余字符 */
t[m++]=s[k];
max=m;/* max是替换后文件的字符总数 */
fp=fopen(a,"w");
printf("\n\nThe results are:\n\n");
for(j=0;j<max;j++)
{putchar(t[j]); /* 结果显示到屏幕 */
fputc(t[j],fp); /* 同时结果写入到当前目录下的新文件001.txt中 */
}
printf("\n\n");
fclose(fp);
system("pause");
return 0;
}

参考资料: http://zhidao.baidu.com/question/100795689.html

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式