[剑指Offer]:替换空格(C/C++详解)

题目描述

请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

正确思路

我们采用一种时间复杂度为 O ( n ) O(n) O(n) 的方法 — 从尾到头遍历(从头到尾遍历 — 时间复杂度为 O ( n 2 ) O(n^2) O(n2)

  • 先遍历一次字符串,这样就可以统计出字符串空格的总数,并可以由此计算出替换之后的字符串的总长度
  • 每替换一个空格,长度增加2,因此替换以后字符串的长度等于原来的长度加上2乘以空格数目

示例:

以"We are happy"为例,“We are happy"这个字符串的长度为14(包括结尾符号”\n"),里面有两个空格,因此替换之后字符串的长度是18。

  • 从字符串的尾部开始复制和替换
  • 首先准备两个指针,P1和P2,P1指向原始字符串的末尾,而P2指向替换之后的字符串的末尾
  • 向前移动指针P1,逐个把它指向的字符复制到P2指向的位置,直到碰到第一个空格为止
  • 碰到第一个空格之后,把P1向前移动1格,在P2之前插入字串"%20"。由于"%20"的长度为3,同时也要把P2向前移动3格。

思路代码:

void replaceSpace(char *str,int length) {
    if(str == NULL ||length<=0) return;
    int sz = 0, count = 0;
    for(int i=0;str[i]!='\0';i++)
    {
        if(str[i] == ' ') count++;
        sz++;
    }
    int new_sz = sz+count*2;
    int i = sz;
    int j = new_sz;
    while(sz>=0 && j>i)
    {
        if(str[i] == ' ')
        {
            str[j--] = '0';
            str[j--] = '2';
            str[j--] = '%';
        }
        else 
            str[j--] = str[i];
        i--;
    }
}

C/C++题解代码

char* replaceSpace(char* s){
    if(*s == '\0') return s;
    char *res = (char *)malloc(strlen(s)*3+1);
    int i = 0;

    while(*s != '\0'){
        if(*s == ' '){
            res[i++] = '%';
            res[i++] = '2';
            res[i++] = '0';
        }else{
            res[i++] = *s;
        }
        s++;
    }
    res[i] = '\0';
    return res;
}
string replaceSpace(string s) {
    int count = 0, len = s.size();
    // 统计空格数量
    for (char c : s) {
        if (c == ' ') count++;
    }
    // 修改 s 长度
    s.resize(len + 2 * count);
    // 倒序遍历修改
    for(int i = len - 1, j = s.size() - 1; i < j; i--, j--) {
        if (s[i] != ' ')
            s[j] = s[i];
        else {
            s[j--] = '0';
            s[j--] = '2';
            s[j] = '%';
        }
    }
    return s;
}

如有不同见解,欢迎留言讨论~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值