剑指offer面试题——替换空格

题目 :请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。在线编程链接见:替换空格

分析:

首先容易想到的就是从前往后扫描,如果空格,就替换为%20,但是这样需要移动空格后的元素。

还有一种方法,首先遍历一遍字符串,统计出空格的个数,并可以由此计算出替换之后的字符串的长度。每替换一个空格,长度增加2,因此替换之后的字符串长度等于原来的长度加上2乘以空格的个数。即替换后的字符串的长度 = 原字符串长度 + 空格数*2。

为了防止字符串覆盖,我们从字符串的后面开始复制和替换。我们首先准备两个指针,p1和p2。指针p1指向原字符串的末尾位置,另一个指针p2指向新字符串的末尾位置。接下来我们移动指针p1,逐个把他指向的字符复制到p2指向的位置,直到碰到一个空格为止。当碰到一个空格时,指针p1向前移动一个位置,在p2之前插入字符串”%20”,同时指针p2向前移动三个位置。

这种思路的代码如下:

void replaceSpace(char *str,int length) {    
        int space_num = 0;
        int strlen = 0;
        for(strlen=0; str[strlen]!='\0'; strlen++)
            if(str[strlen] == ' ') space_num++;
        int newlen = strlen + 2*space_num;
        if(newlen>length) return;
        while(strlen>=0){
            if(str[strlen]==' '){
                str[newlen--] = '0';
                str[newlen--] = '2';
                str[newlen--] = '%';
                strlen--;
            }
            else str[newlen--] = str[strlen--];
        }
    }

当然也可以不用统计空格的个数,这时需要新建一个临时的string变量存储空格替换后的字符串,再将字符串替换为原char*数组即可,这个思路代码如下:

void replaceSpace(char *str,int length) {
        string s = "";
        for(int i = 0;(str)[i]!='\0';++i)
        {
            if((str)[i] == ' ')
            {
                s += '%';
                s += '2';
                s += '0';
            }
            else
                s += (str)[i];
        }
        for(int i = s.length();i >= 0 ;--i)
            (str)[i] = s[i];
    }
值得注意的地方是:最后两行代码不能从前往后复制,而是要从后往前复制。如果从前往后复制会产生类似于“烫烫。。。”这样的错误。

参考资料:

【剑指offer面试题4】替换空格%20和清除空格

你可能感兴趣的:(算法与数据结构,C++知识总结)