c语言:如何将字符串中指定的字符替换为另一个指定字符

Python010

c语言:如何将字符串中指定的字符替换为另一个指定字符,第1张

/*功能:将str字符串中的oldstr字符串替换为newstr字符串

*参数:str:操作目标oldstr:被替换者newstr:替换者

*返回值:返回替换之后的字符串

*版本:V0.2

*/

char*strrpc(char*str,char*oldstr,char*newstr){

char bstr[strlen(str)]//转换缓冲区

memset(bstr,0,sizeof(bstr))

for(int i=0i&ltstrlen(str)i++){

if(!strncmp(str+i,oldstr,strlen(oldstr))){//查找目标字符串

strcat(bstr,newstr)

i+=strlen(oldstr)-1

}else{

strncat(bstr,str+i,1)//保存一字节进缓冲区

}

}

strcpy(str,bstr)

return str

}

扩展资料:

c_str函数的返回值是constchar*的,不能直接赋值给char*,所以就需要我们进行相应的操作转化,下面就是这一转化过程。

c++语言提供了两种字符串实现,其中较原始的一种只是字符串的c语言实现。与C语言的其他部分一样,它在c++的所有实现中可用,我们将这种实现提供的字符串对象,归为c-串,每个c-串char*类型的。

标准头文件&ltcstring&gt包含操作c-串的函数库。这些库函数表达了我们希望使用的几乎每种字符串操作。

当调用库函数,客户程序提供的是string类型参数,而库函数内部实现用的是c-串,因此需要将string对象,转化为char*对象,而c_str()提供了这样一种方法,它返回const char*类型(可读不可改)的指向字符数组的指针。例:

#include&ltiostream&gt

//#include&ltcstring&gt

#include&ltstring&gt//使用头文件string,否则最后cout&lt&lt无法输出add_to

using namespace std

int main()

{

string add_to="hello!"

const string add_on="baby"

const char*cfirst=add_to.c_str()

const char*csecond=add_on.c_str()

char*copy=new char[strlen(cfirst)+strlen(csecond)+1]

strcpy(copy,cfirst)

strcat(copy,csecond)

add_to=copy

cout&lt&lt"copy:"&lt&ltcopy&lt&ltendl

delete[]copy

cout&lt&lt"add_to:"&lt&ltadd_to&lt&ltendl

return 0

}

例(1)

函数声明:const char*c_str()

c_str()函数返回一个指向正规C字符串的指针,内容与本string串相同.

这是为了与c语言兼容,在c语言中没有string类型,故必须通过string类对象的成员函数c_str()把string对象转换成c中的字符串样式。

注意:一定要使用strcpy()函数等来操作方法c_str()返回的指针

比如:最好不要这样:

char*c

string s="1234"

c=s.c_str()

//c最后指向的内容是垃圾,因为s对象被析构,其内容被处理(纠正:s对象的析构是在s的生命周期结束时,例如函数的返回)

参考资料:

百度百科——c_str

效果图:

代码:

#include<stdio.h>

int getLen(char a[]) {

int len = 0

while (a[len] != '\0')len++

return len

}

int find(char a[], char b[], int idx) {

int la = getLen(a), lb = getLen(b), t = la - lb, i, f

for ( idx <= t idx++) {

f = 0

for (i = 0 i < lb i++) {

if (a[idx + i] != b[i]) { f = 1 break }

}

if (f == 0)return idx

}

return -1

}

int main() {

char a[1024], b[1024], cmp[1025]

int i = 0, j , la, lc

scanf("%s", a)

scanf("%s", cmp)

scanf("%s", b)

la = getLen(a)

lc = getLen(cmp)

j = 0 - lc

while (1) {

j = find(a, cmp, j + lc)

if (j == -1) {

while (i < la) {

printf("%c", a[i++])

}

break

}

for ( i < j i++)printf("%c", a[i])

i += lc

printf("%s", b)

}

printf("\n")

}

答题不易,如无疑问,觉得可以的话,采纳一下