【C++编程题】字符串子串替换

题目描述

  1. 编写函数void reOnce(char src[], char obj[], char sub[]),函数功能是用sub字符串替换长串src内第一次出现的obj子串。

  2. 编写函数void repAll(char src[], char obj[], char sub[]),函数功能是用sub字符串替换长串src内出现所有的obj子串。

void repOnce(char src[], char obj[], char sub[]);
void repAll(char src[], char obj[], char sub[]);

原始代码:

#include <iostream>
#include <cstring>
using namespace std;
void repOnce(char src[], char obj[], char sub[]);
void repAll(char src[], char obj[], char sub[]);

int main(){
    char c[100],obj[100],sub[100];

    cout << "依次输入src,obj,sub:"<<endl;
    cin.getline(c,100);
    cin.getline(obj,100);
    cin.getline(sub,100);
    repOnce(c, obj, sub);
    cout << c << endl;

    cout << "依次输入src,obj,sub:"<<endl;
    cin.getline(c,100);
    cin.getline(obj,100);
    cin.getline(sub,100);
    repAll(c, obj, sub);
    cout << c << endl;
    return 0;
}

void repOnce(char src[], char obj[], char sub[]){
	/*--------Your Code Here--------*/
}

void repAll(char src[], char obj[], char sub[]){
	/*--------Your Code Here--------*/
}

题目提示

cin.getline允许读取包含空格的字符串。它将持续读取,直到它读取至最大指定的字符数,或直到按下了回车键。

可使用库函数strcpy strcmp strncpy strncmp strstr等。

strcpy函数:strcpy(char ds[], char ss[]),作用是把ss字符串复制给ds指向的内存区域。

strncmp函数:int strncmp (char ds[], char ss[], int len),作用是比较ds串和ss串中的前面len个字符,如果相同返回0,如果ds<ss,返回-1,否则返回1。

strncpy函数:strncpy(char ds[], char ss[], int len),作用是把ss中的前len个字符复制到ds指向的内存区域。

strstr函数:char *strstr(const char *s, const char *needle) 在字符串s中查找第一次出现字符串 needle 的位置,不包含终止符 ‘\0’。
该函数返回在s中第一次出现 needle 字符串的位置,如果未找到则返回 null。

参考代码

1. 一次替换

void repOnce(char src[], char obj[], char sub[]){
    char *p = strstr(src, obj);
    char tail[100];
    strcpy(tail,p+strlen(obj));
    strcpy(p,sub);
    strcpy(p+strlen(sub), tail);
}

2. 全部替换

解法一

void repAll(char src[], char obj[], char sub[]){
    while(strstr(src,obj)) 
    	repOnce(src,obj,sub);
}

解法二

void repAll(char src[], char obj[], char sub[]){
    //while(strstr(src,obj)) repOnce(src,obj,sub);
    char *p = src;
    char target[100], *q = target;
    while(*p!='\0'){
        if(strncmp(p, obj, strlen(obj))==0){
            strcpy(q,sub);
            p += strlen(obj);
            q += strlen(sub);
        }
        else
            *q++ = *p++;
    }
    *q = '\0';
    strcpy(src,target);
}

完整代码

#include <iostream>
#include <cstring>
using namespace std;
void repOnce(char src[], char obj[], char sub[]);
void repAll(char src[], char obj[], char sub[]);

int main(){
    char c[100],obj[100],sub[100];

    cout << "依次输入src,obj,sub:"<<endl;
    cin.getline(c,100);
    cin.getline(obj,100);
    cin.getline(sub,100);
    repOnce(c, obj, sub);
    cout << c << endl;

    cout << "依次输入src,obj,sub:"<<endl;
    cin.getline(c,100);
    cin.getline(obj,100);
    cin.getline(sub,100);
    repAll(c, obj, sub);
    cout << c << endl;
    return 0;
}

void repOnce(char src[], char obj[], char sub[]){
    char *p = strstr(src, obj);
    char tail[100];
    strcpy(tail,p+strlen(obj));
    strcpy(p,sub);
    strcpy(p+strlen(sub), tail);
}

void repAll(char src[], char obj[], char sub[]){
    while(strstr(src,obj)) repOnce(src,obj,sub);
}
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值