请实现一个函数,将一个字符串中的空格替换成

class Solution {
public:
    void replaceSpace(char *str, int length) {
        if (str == NULL || length<0)//非空判断
            return ;
        int i = 0;
        int oldlength = 0;//字符串的长度
        int count = 0;//记录空格的数量
        while (str[i] != '\0')//遍历字符串,记录字符数和空格数
        {
            oldlength++;
            if (str[i] == ' ')
            {
                count++;
            }
            i++;
        }
        int newlength = oldlength + count * 2;//插入后字符串的长度
        if (newlength>length)//如果替换后的长度大于给定长度则替换失败
            return ;
        int pOldlength = oldlength; //注意不要减一因为隐藏个‘\0’也要算里
        int pNewlength = newlength;
        while (pOldlength >= 0 && pNewlength>pOldlength)//放字符
        {
            if (str[pOldlength] == ' ') //碰到空格就替换
            {
                str[pNewlength--] = '0';
                str[pNewlength--] = '2';
                str[pNewlength--] = '%';

            }
            else //不是空格就把pOldlength指向的字符装入pNewlength指向的位置
            {
                str[pNewlength--] = str[pOldlength];

            }
            --pOldlength; //不管是if还是else都要把pOldlength前移

        }
    }
};

猜你喜欢

转载自blog.csdn.net/qq_38224589/article/details/81982797
今日推荐