/*功能:将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")
}
答题不易,如无疑问,觉得可以的话,采纳一下